

# NuMicro® Family

## M480 Series

### Technical Reference Manual

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

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

*All data and specifications are subject to change without notice.*

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

[www.nuvoton.com](http://www.nuvoton.com)

**TABLE OF CONTENTS**

|                                                                                   |            |
|-----------------------------------------------------------------------------------|------------|
| <b>1 GENERAL DESCRIPTION.....</b>                                                 | <b>31</b>  |
| <b>2 FEATURE DESCRIPTION .....</b>                                                | <b>32</b>  |
| <b>3 PARTS INFORMATION .....</b>                                                  | <b>44</b>  |
| <b>3.1 Summary .....</b>                                                          | <b>44</b>  |
| <b>3.2 Package Type .....</b>                                                     | <b>44</b>  |
| <b>3.3 NuMicro® M481 Base Series .....</b>                                        | <b>45</b>  |
| <b>3.4 NuMicro® M482 USB FS OTG Series .....</b>                                  | <b>46</b>  |
| <b>3.5 NuMicro® M483 CAN Series.....</b>                                          | <b>47</b>  |
| <b>3.6 NuMicro® M484 USB HS OTG Series.....</b>                                   | <b>48</b>  |
| <b>3.7 NuMicro® M485 Crypto Series.....</b>                                       | <b>49</b>  |
| <b>3.8 NuMicro® M487 Ethernet Series .....</b>                                    | <b>50</b>  |
| <b>3.9 NuMicro® M480 Naming Rule .....</b>                                        | <b>51</b>  |
| <b>4 PIN CONFIGURATION .....</b>                                                  | <b>52</b>  |
| <b>4.1 Pin Configuration .....</b>                                                | <b>52</b>  |
| <b>4.1.1 NuMicro® M481 Base Series QFN33 Pin Diagram .....</b>                    | <b>52</b>  |
| <b>4.1.2 NuMicro® M481 Base Series LQFP48 Pin Diagram .....</b>                   | <b>53</b>  |
| <b>4.1.3 NuMicro® M481 Base Series LQFP64 Pin Diagram .....</b>                   | <b>54</b>  |
| <b>4.1.4 NuMicro® M482 USB FS OTG Series QFN33 Pin Diagram .....</b>              | <b>55</b>  |
| <b>4.1.5 NuMicro® M482 USB FS OTG Series LQFP48 Pin Diagram .....</b>             | <b>56</b>  |
| <b>4.1.6 NuMicro® M482 USB FS OTG Series LQFP64 Pin Diagram .....</b>             | <b>57</b>  |
| <b>4.1.7 NuMicro® M482 USB FS OTG Series LQFP128 Pin Diagram .....</b>            | <b>58</b>  |
| <b>4.1.8 NuMicro® M483 CAN Series LQFP64 Pin Diagram .....</b>                    | <b>59</b>  |
| <b>4.1.9 NuMicro® M483 CAN Series LQFP128 Pin Diagram .....</b>                   | <b>60</b>  |
| <b>4.1.10 NuMicro® M484 USB HS OTG Series LQFP64 Pin Diagram .....</b>            | <b>61</b>  |
| <b>4.1.11 NuMicro® M484 USB HS OTG Series with 2 USB LQFP64 Pin Diagram .....</b> | <b>62</b>  |
| <b>4.1.12 NuMicro® M484 USB HS OTG Series LQFP128 Pin Diagram .....</b>           | <b>63</b>  |
| <b>4.1.13 NuMicro® M485 Crypto Series QFN33 Pin Diagram .....</b>                 | <b>64</b>  |
| <b>4.1.14 NuMicro® M485 Crypto Series LQFP48 Pin Diagram .....</b>                | <b>65</b>  |
| <b>4.1.15 NuMicro® M485 Crypto Series LQFP64 Pin Diagram .....</b>                | <b>66</b>  |
| <b>4.1.16 NuMicro® M485 Crypto Series LQFP128 Pin Diagram .....</b>               | <b>67</b>  |
| <b>4.1.17 NuMicro® M487 Ethernet Series LQFP64 Pin Diagram .....</b>              | <b>68</b>  |
| <b>4.1.18 NuMicro® M487 Ethernet Series LQFP128 Pin Diagram .....</b>             | <b>69</b>  |
| <b>4.1.19 NuMicro® M487 Ethernet Series LQFP144 Pin Diagram .....</b>             | <b>70</b>  |
| <b>4.2 Pin Description.....</b>                                                   | <b>71</b>  |
| <b>4.2.1 M481 Series Pin Description .....</b>                                    | <b>71</b>  |
| <b>4.2.2 M482 Series Pin Description .....</b>                                    | <b>88</b>  |
| <b>4.2.3 M483 Series Pin Description .....</b>                                    | <b>117</b> |

|          |                                                        |            |
|----------|--------------------------------------------------------|------------|
| 4.2.4    | M484 Series Pin Description .....                      | 145        |
| 4.2.5    | M485 Series Pin Description .....                      | 172        |
| 4.2.6    | M487 Series Pin Description .....                      | 200        |
| 4.2.7    | M480 Multi-function Summary Table .....                | 231        |
| 4.2.8    | M480 Multi-function Summary Table Sorted by GPIO ..... | 258        |
| <b>5</b> | <b>BLOCK DIAGRAM.....</b>                              | <b>289</b> |
| 5.1      | NuMicro® M480 Block Diagram.....                       | 289        |
| <b>6</b> | <b>FUNCTIONAL DESCRIPTION.....</b>                     | <b>290</b> |
| 6.1      | ARM® Cortex® -M4 Core.....                             | 290        |
| 6.2      | System Manager.....                                    | 293        |
| 6.2.1    | Overview.....                                          | 293        |
| 6.2.2    | System Reset.....                                      | 293        |
| 6.2.3    | System Power Distribution .....                        | 299        |
| 6.2.4    | Power Modes and Wake-up Sources .....                  | 300        |
| 6.2.5    | Power Modes and Power Level Transition .....           | 304        |
| 6.2.6    | System Memory Map .....                                | 304        |
| 6.2.7    | SRAM Memory Organization .....                         | 308        |
| 6.2.8    | Bus Matrix.....                                        | 310        |
| 6.2.9    | HIRC Auto Trim .....                                   | 310        |
| 6.2.10   | Register Lock Control .....                            | 311        |
| 6.2.11   | Register Map .....                                     | 314        |
| 6.2.12   | Register Description .....                             | 316        |
| 6.2.13   | System Timer (SysTick).....                            | 368        |
| 6.2.14   | System Timer Control Register Map.....                 | 369        |
| 6.2.15   | Nested Vectored Interrupt Controller (NVIC).....       | 373        |
| 6.2.16   | System Control Register .....                          | 403        |
| 6.3      | Clock Controller .....                                 | 412        |
| 6.3.1    | Overview .....                                         | 412        |
| 6.3.2    | Clock Generator.....                                   | 414        |
| 6.3.3    | System Clock and SysTick Clock.....                    | 415        |
| 6.3.4    | Peripherals Clock .....                                | 416        |
| 6.3.5    | Power-down Mode Clock .....                            | 417        |
| 6.3.6    | Clock Output.....                                      | 417        |
| 6.3.7    | USB Clock Source.....                                  | 418        |
| 6.3.8    | HXT clock .....                                        | 419        |
| 6.3.9    | Register Map .....                                     | 420        |
| 6.3.10   | Register Description .....                             | 422        |
| 6.4      | Flash Memory Controller (FMC).....                     | 468        |
| 6.4.1    | Overview .....                                         | 468        |
| 6.4.2    | Features.....                                          | 468        |
| 6.4.3    | Block Diagram.....                                     | 468        |

|                                          |     |
|------------------------------------------|-----|
| 6.4.4 Functional Description .....       | 471 |
| 6.4.5 Register Map .....                 | 511 |
| 6.4.6 Register Description .....         | 512 |
| 6.5 General Purpose I/O (GPIO) .....     | 538 |
| 6.5.1 Overview .....                     | 538 |
| 6.5.2 Features .....                     | 538 |
| 6.5.3 Block Diagram .....                | 539 |
| 6.5.4 Basic Configuration .....          | 539 |
| 6.5.5 Functional Description .....       | 540 |
| 6.5.6 Register Map .....                 | 543 |
| 6.5.7 Register Description .....         | 547 |
| 6.6 PDMA Controller (PDMA) .....         | 564 |
| 6.6.1 Overview .....                     | 564 |
| 6.6.2 Features .....                     | 564 |
| 6.6.3 Block Diagram .....                | 564 |
| 6.6.4 Basic Configuration .....          | 564 |
| 6.6.5 Functional Description .....       | 565 |
| 6.6.6 Register Map .....                 | 571 |
| 6.6.7 Register Description .....         | 573 |
| 6.7 Timer Controller (TMR) .....         | 605 |
| 6.7.1 Overview .....                     | 605 |
| 6.7.2 Features .....                     | 605 |
| 6.7.3 Block Diagram .....                | 606 |
| 6.7.4 Basic Configuration .....          | 610 |
| 6.7.5 Timer Functional Description ..... | 611 |
| 6.7.6 PWM Functional Description .....   | 616 |
| 6.7.7 Register Map .....                 | 633 |
| 6.7.8 Register Description .....         | 639 |
| 6.8 Watchdog Timer (WDT) .....           | 682 |
| 6.8.1 Overview .....                     | 682 |
| 6.8.2 Features .....                     | 682 |
| 6.8.3 Block Diagram .....                | 682 |
| 6.8.4 Basic Configuration .....          | 682 |
| 6.8.5 Functional Description .....       | 683 |
| 6.8.6 Register Map .....                 | 686 |
| 6.8.7 Register Description .....         | 687 |
| 6.9 Window Watchdog Timer (WWDT) .....   | 691 |
| 6.9.1 Overview .....                     | 691 |
| 6.9.2 Features .....                     | 691 |
| 6.9.3 Block Diagram .....                | 691 |
| 6.9.4 Basic Configuration .....          | 691 |

|                                                        |     |
|--------------------------------------------------------|-----|
| 6.9.5 Functional Description .....                     | 692 |
| 6.9.6 Register Map .....                               | 696 |
| 6.9.7 Register Description .....                       | 697 |
| 6.10 Real Time Clock (RTC).....                        | 702 |
| 6.10.1 Overview .....                                  | 702 |
| 6.10.2 Features.....                                   | 702 |
| 6.10.3 Block Diagram.....                              | 703 |
| 6.10.4 Basic Configuration .....                       | 703 |
| 6.10.5 Functional Description .....                    | 705 |
| 6.10.6 Register Map .....                              | 712 |
| 6.10.7 Register Description .....                      | 714 |
| 6.11 EPWM Generator and Capture Timer (EPWM).....      | 748 |
| 6.11.1 Overview .....                                  | 748 |
| 6.11.2 Features.....                                   | 748 |
| 6.11.3 Block Diagram.....                              | 749 |
| 6.11.4 Basic Configuration .....                       | 753 |
| 6.11.5 Functional Description .....                    | 755 |
| 6.11.6 Register Map .....                              | 788 |
| 6.11.7 Register Description.....                       | 794 |
| 6.12 Basic PWM Generator and Capture Timer (BPWM)..... | 863 |
| 6.12.1 Overview .....                                  | 863 |
| 6.12.2 Features.....                                   | 863 |
| 6.12.3 Block Diagram.....                              | 864 |
| 6.12.4 Basic Configuration .....                       | 867 |
| 6.12.5 Functional Description .....                    | 868 |
| 6.12.6 Register Map .....                              | 883 |
| 6.12.7 Register Description.....                       | 886 |
| 6.13 Quadrature Encoder Interface (QEI) .....          | 919 |
| 6.13.1 Overview .....                                  | 919 |
| 6.13.2 Features.....                                   | 919 |
| 6.13.3 Block Diagram.....                              | 919 |
| 6.13.4 Basic Configuration .....                       | 920 |
| 6.13.5 Functional Description .....                    | 921 |
| 6.13.6 Register Map .....                              | 929 |
| 6.13.7 Register Description.....                       | 930 |
| 6.14 Enhanced Input Capture Timer (ECAP).....          | 940 |
| 6.14.1 Overview .....                                  | 940 |
| 6.14.2 Features.....                                   | 940 |
| 6.14.3 Block Diagram.....                              | 940 |
| 6.14.4 Basic Configuration .....                       | 941 |
| 6.14.5 Functional Description .....                    | 942 |

|                                                             |      |
|-------------------------------------------------------------|------|
| 6.14.6 Register Map .....                                   | 947  |
| 6.14.7 Register Description .....                           | 948  |
| 6.15   UART Interface Controller (UART).....                | 960  |
| 6.15.1 Overview .....                                       | 960  |
| 6.15.2 Features.....                                        | 960  |
| 6.15.3 Block Diagram.....                                   | 961  |
| 6.15.4 Basic Configuration .....                            | 964  |
| 6.15.5 Functional Description .....                         | 968  |
| 6.15.6 Register Map .....                                   | 993  |
| 6.15.7 Register Description .....                           | 995  |
| 6.16   Ethernet MAC Controller (EMAC).....                  | 1029 |
| 6.16.1 Overview .....                                       | 1029 |
| 6.16.2 Features.....                                        | 1029 |
| 6.16.3 Block Diagram.....                                   | 1030 |
| 6.16.4 Basic Configuration .....                            | 1030 |
| 6.16.5 Functional Description .....                         | 1031 |
| 6.16.6 Register Map .....                                   | 1047 |
| 6.16.7 Register Description .....                           | 1050 |
| 6.17   Smart Card Host Interface (SC) .....                 | 1102 |
| 6.17.1 Overview .....                                       | 1102 |
| 6.17.2 Features.....                                        | 1102 |
| 6.17.3 Block Diagram.....                                   | 1102 |
| 6.17.4 Basic Configuration .....                            | 1104 |
| 6.17.5 Functional Description .....                         | 1107 |
| 6.17.6 Register Map .....                                   | 1119 |
| 6.17.7 Register Description .....                           | 1120 |
| 6.18   I <sup>2</sup> S Controller (I <sup>2</sup> S) ..... | 1144 |
| 6.18.1 Overview .....                                       | 1144 |
| 6.18.2 Features.....                                        | 1144 |
| 6.18.3 Block Diagram.....                                   | 1144 |
| 6.18.4 Basic Configuration .....                            | 1144 |
| 6.18.5 Functional Description .....                         | 1145 |
| 6.18.6 Register Map .....                                   | 1156 |
| 6.18.7 Register Description .....                           | 1157 |
| 6.19   Serial Peripheral Interface (SPI).....               | 1175 |
| 6.19.1 Overview .....                                       | 1175 |
| 6.19.2 Features.....                                        | 1175 |
| 6.19.3 Block Diagram.....                                   | 1176 |
| 6.19.4 Basic Configuration .....                            | 1176 |
| 6.19.5 Functional Description .....                         | 1180 |
| 6.19.6 Timing Diagram.....                                  | 1193 |

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| 6.19.7 Programming Examples .....                                         | 1194 |
| 6.19.8 Register Map .....                                                 | 1197 |
| 6.19.9 Register Description .....                                         | 1198 |
| 6.20 Quad Serial Peripheral Interface (QSPI).....                         | 1218 |
| 6.20.1 Overview .....                                                     | 1218 |
| 6.20.2 Features.....                                                      | 1218 |
| 6.20.3 Block Diagram.....                                                 | 1218 |
| 6.20.4 Basic Configuration .....                                          | 1219 |
| 6.20.5 Functional Description .....                                       | 1220 |
| 6.20.6 Timing Diagram.....                                                | 1236 |
| 6.20.7 Programming Examples .....                                         | 1238 |
| 6.20.8 Register Map .....                                                 | 1241 |
| 6.20.9 Register Description.....                                          | 1242 |
| 6.21 SPI Synchronous Serial Interface Controller (SPI Master mode) .....  | 1256 |
| 6.21.1 Overview .....                                                     | 1256 |
| 6.21.2 Features.....                                                      | 1256 |
| 6.21.3 Block Diagram.....                                                 | 1258 |
| 6.21.4 Basic Configuration .....                                          | 1258 |
| 6.21.5 Functional Description .....                                       | 1259 |
| 6.21.6 Mapping Address for SPI Flash Controller in AMBA System .....      | 1269 |
| 6.21.7 Register Map .....                                                 | 1270 |
| 6.21.8 Register Description .....                                         | 1271 |
| 6.22 I <sup>2</sup> C Serial Interface Controller (I <sup>2</sup> C)..... | 1290 |
| 6.22.1 Overview .....                                                     | 1290 |
| 6.22.2 Features.....                                                      | 1290 |
| 6.22.3 Block Diagram.....                                                 | 1291 |
| 6.22.4 Basic Configuration .....                                          | 1291 |
| 6.22.5 Functional Description .....                                       | 1293 |
| 6.22.6 Register Map .....                                                 | 1316 |
| 6.22.7 Register Description .....                                         | 1317 |
| 6.23 USCI - Universal Serial Control Interface Controller (USCI).....     | 1339 |
| 6.23.1 Overview .....                                                     | 1339 |
| 6.23.2 Features.....                                                      | 1339 |
| 6.23.3 Block Diagram.....                                                 | 1339 |
| 6.23.4 Functional Description .....                                       | 1339 |
| 6.24 USCI – UART Mode .....                                               | 1350 |
| 6.24.1 Overview .....                                                     | 1350 |
| 6.24.2 Features.....                                                      | 1350 |
| 6.24.3 Block Diagram.....                                                 | 1350 |
| 6.24.4 Basic Configuration .....                                          | 1351 |
| 6.24.5 Functional Description .....                                       | 1352 |

|                                                 |      |
|-------------------------------------------------|------|
| 6.24.6 Register Map .....                       | 1361 |
| 6.24.7 Register Description .....               | 1362 |
| 6.25 USCI - SPI Mode .....                      | 1384 |
| 6.25.1 Overview .....                           | 1384 |
| 6.25.2 Features .....                           | 1384 |
| 6.25.3 Block Diagram .....                      | 1385 |
| 6.25.4 Basic Configuration .....                | 1385 |
| 6.25.5 Functional Description .....             | 1386 |
| 6.25.6 Register Map .....                       | 1400 |
| 6.25.7 Register Description .....               | 1401 |
| 6.26 USCI - I <sup>2</sup> C Mode .....         | 1424 |
| 6.26.1 Overview .....                           | 1424 |
| 6.26.2 Features .....                           | 1424 |
| 6.26.3 Block Diagram .....                      | 1425 |
| 6.26.4 Basic Configuration .....                | 1425 |
| 6.26.5 Functional Description .....             | 1426 |
| 6.26.6 Register Map .....                       | 1445 |
| 6.26.7 Register Description .....               | 1446 |
| 6.27 Controller Area Network (CAN) .....        | 1464 |
| 6.27.1 Overview .....                           | 1464 |
| 6.27.2 Features .....                           | 1464 |
| 6.27.3 Block Diagram .....                      | 1464 |
| 6.27.4 Basic Configuration .....                | 1465 |
| 6.27.5 Functional Description .....             | 1466 |
| 6.27.6 Test Mode .....                          | 1467 |
| 6.27.7 CAN Communications .....                 | 1470 |
| 6.27.8 Register Map .....                       | 1486 |
| 6.27.9 Register Description .....               | 1491 |
| 6.28 Secure Digital Host Controller (SDH) ..... | 1526 |
| 6.28.1 Overview .....                           | 1526 |
| 6.28.2 Features .....                           | 1526 |
| 6.28.3 Block Diagram .....                      | 1527 |
| 6.28.4 Basic Configuration .....                | 1527 |
| 6.28.5 Functional Description .....             | 1528 |
| 6.28.6 Register Map .....                       | 1531 |
| 6.28.7 Register Description .....               | 1532 |
| 6.29 External Bus Interface (EBI) .....         | 1551 |
| 6.29.1 Overview .....                           | 1551 |
| 6.29.2 Features .....                           | 1551 |
| 6.29.3 Block Diagram .....                      | 1552 |
| 6.29.4 Basic Configuration .....                | 1552 |

|                                                          |      |
|----------------------------------------------------------|------|
| 6.29.5 Functional Description .....                      | 1554 |
| 6.29.6 Register Map .....                                | 1564 |
| 6.29.7 Register Description .....                        | 1565 |
| 6.30 USB 1.1 Device Controller (USBD) .....              | 1569 |
| 6.30.1 Overview .....                                    | 1569 |
| 6.30.2 Features .....                                    | 1569 |
| 6.30.3 Block Diagram .....                               | 1570 |
| 6.30.4 Basic Configuration .....                         | 1570 |
| 6.30.5 Functional Description .....                      | 1571 |
| 6.30.6 Register Map .....                                | 1576 |
| 6.30.7 Register Description .....                        | 1579 |
| 6.31 High Speed USB 2.0 Device Controller (HSUSBD) ..... | 1603 |
| 6.31.1 Overview .....                                    | 1603 |
| 6.31.2 Features .....                                    | 1603 |
| 6.31.3 Block Diagram .....                               | 1603 |
| 6.31.4 Basic Configuration .....                         | 1603 |
| 6.31.5 Functional Description .....                      | 1604 |
| 6.31.6 Registers Map .....                               | 1606 |
| 6.31.7 Register Description .....                        | 1611 |
| 6.32 USB 2.0 Host Controller (USBH) .....                | 1661 |
| 6.32.1 Overview .....                                    | 1661 |
| 6.32.2 Features .....                                    | 1661 |
| 6.32.3 Block Diagram .....                               | 1662 |
| 6.32.4 Basic Configuration .....                         | 1663 |
| 6.32.5 Functional Description .....                      | 1663 |
| 6.32.6 Register Map .....                                | 1665 |
| 6.32.7 Register Description .....                        | 1667 |
| 6.33 USB On-The-Go (OTG) .....                           | 1718 |
| 6.33.1 Overview .....                                    | 1718 |
| 6.33.2 Features .....                                    | 1718 |
| 6.33.3 Block Diagram .....                               | 1718 |
| 6.33.4 Basic Configuration .....                         | 1719 |
| 6.33.5 Functional Description .....                      | 1719 |
| 6.33.6 Register Map .....                                | 1722 |
| 6.33.7 Register Description .....                        | 1723 |
| 6.34 High Speed USB On-The-Go (HSOTG) .....              | 1732 |
| 6.34.1 Overview .....                                    | 1732 |
| 6.34.2 Features .....                                    | 1732 |
| 6.34.3 Block Diagram .....                               | 1732 |
| 6.34.4 Basic Configuration .....                         | 1733 |
| 6.34.5 Functional Description .....                      | 1733 |

|                                                               |      |
|---------------------------------------------------------------|------|
| 6.34.6 Register Map .....                                     | 1737 |
| 6.34.7 Register Description .....                             | 1738 |
| 6.35 CRC Controller (CRC) .....                               | 1747 |
| 6.35.1 Overview .....                                         | 1747 |
| 6.35.2 Features .....                                         | 1747 |
| 6.35.3 Block Diagram .....                                    | 1747 |
| 6.35.4 Basic Configuration .....                              | 1748 |
| 6.35.5 Functional Description .....                           | 1748 |
| 6.35.6 Register Map .....                                     | 1750 |
| 6.35.7 Register Description .....                             | 1751 |
| 6.36 Cryptographic Accelerator (CRYPTO) .....                 | 1756 |
| 6.36.1 Overview .....                                         | 1756 |
| 6.36.2 Features .....                                         | 1756 |
| 6.36.3 Block Diagram .....                                    | 1757 |
| 6.36.4 Basic Configuration .....                              | 1758 |
| 6.36.5 Functional Description .....                           | 1758 |
| 6.36.6 Register Map .....                                     | 1780 |
| 6.36.7 Register Description .....                             | 1791 |
| 6.37 Enhanced 12-bit Analog-to-Digital Converter (EADC) ..... | 1858 |
| 6.37.1 Overview .....                                         | 1858 |
| 6.37.2 Features .....                                         | 1858 |
| 6.37.3 Block Diagram .....                                    | 1859 |
| 6.37.4 Basic Configuration .....                              | 1859 |
| 6.37.5 Functional Description .....                           | 1860 |
| 6.37.6 Register Map .....                                     | 1875 |
| 6.37.7 Register Description .....                             | 1878 |
| 6.38 Digital to Analog Converter (DAC) .....                  | 1908 |
| 6.38.1 Overview .....                                         | 1908 |
| 6.38.2 Features .....                                         | 1908 |
| 6.38.3 Block Diagram .....                                    | 1909 |
| 6.38.4 Basic Configuration .....                              | 1909 |
| 6.38.5 Functional Description .....                           | 1910 |
| 6.38.6 Register Map .....                                     | 1915 |
| 6.38.7 Register Description .....                             | 1916 |
| 6.39 Analog Comparator Controller (ACMP) .....                | 1930 |
| 6.39.1 Overview .....                                         | 1930 |
| 6.39.2 Features .....                                         | 1930 |
| 6.39.3 Block Diagram .....                                    | 1931 |
| 6.39.4 Basic Configuration .....                              | 1931 |
| 6.39.5 Functional Description .....                           | 1932 |
| 6.39.6 Register Map .....                                     | 1937 |

|                                                                                            |             |
|--------------------------------------------------------------------------------------------|-------------|
| 6.39.7 Register Description .....                                                          | 1938        |
| <b>6.40 OP Amplifier (OPA) .....</b>                                                       | <b>1945</b> |
| 6.40.1 Overview .....                                                                      | 1945        |
| 6.40.2 Features .....                                                                      | 1945        |
| 6.40.3 Block Diagram .....                                                                 | 1946        |
| 6.40.4 Basic Configuration .....                                                           | 1946        |
| 6.40.5 Functional Description .....                                                        | 1947        |
| 6.40.6 Register Map .....                                                                  | 1949        |
| 6.40.7 Register Description .....                                                          | 1950        |
| <b>7 APPLICATION CIRCUIT .....</b>                                                         | <b>1957</b> |
| 7.1 Power Supply Scheme with External V <sub>REF</sub> .....                               | 1957        |
| 7.2 Power Supply Scheme with Internal V <sub>REF</sub> .....                               | 1958        |
| 7.3 Power Supply Scheme with External V <sub>REF</sub> and External RTC with Battery Power | 1959        |
| 7.4 Power Supply Scheme with External V <sub>REF</sub> and Internal RTC with Battery Power | 1960        |
| 7.5 Peripheral Application scheme .....                                                    | 1961        |
| <b>8 ELECTRICAL CHARACTERISTICS .....</b>                                                  | <b>1962</b> |
| <b>9 PACKAGE DIMENSIONS .....</b>                                                          | <b>1963</b> |
| 9.1 QFN 33L (5x5x0.8 mm <sup>3</sup> Pitch 0.5 mm) .....                                   | 1963        |
| 9.2 LQFP 48L (7x7x1.4 mm <sup>3</sup> Footprint 2.0mm) .....                               | 1964        |
| 9.3 LQFP 64L (7x7x1.4 mm <sup>3</sup> Footprint 2.0 mm) .....                              | 1965        |
| 9.4 LQFP 128L (14x14x1.4 mm <sup>3</sup> Footprint 2.0 mm) .....                           | 1966        |
| 9.5 LQFP 144L (20x20x1.4 mm <sup>3</sup> Footprint 2.0 mm) .....                           | 1967        |
| <b>10 ABBREVIATIONS .....</b>                                                              | <b>1968</b> |
| 10.1 Abbreviations .....                                                                   | 1968        |
| <b>11 REVISION HISTORY .....</b>                                                           | <b>1970</b> |

**LIST OF FIGURES**

|                                                                                    |     |
|------------------------------------------------------------------------------------|-----|
| Figure 4.1-1 NuMicro® M481 Base Series QFN 33-pin Diagram.....                     | 52  |
| Figure 4.1-2 NuMicro® M481 Base Series LQFP 48-pin Diagram.....                    | 53  |
| Figure 4.1-3 NuMicro® M481 Base Series LQFP 64-pin Diagram.....                    | 54  |
| Figure 4.1-4 NuMicro® M482 USB FS OTG Series QFN 33-pin Diagram .....              | 55  |
| Figure 4.1-5 NuMicro® M482 USB FS OTG Series LQFP 48-pin Diagram .....             | 56  |
| Figure 4.1-6 NuMicro® M482 USB FS OTG Series LQFP 64-pin Diagram .....             | 57  |
| Figure 4.1-7 NuMicro® M482 USB FS OTG Series LQFP 128-pin Diagram .....            | 58  |
| Figure 4.1-8 NuMicro® M483 CAN Series LQFP 64-pin Diagram.....                     | 59  |
| Figure 4.1-9 NuMicro® M483 CAN Series LQFP 128-pin Diagram.....                    | 60  |
| Figure 4.1-10 NuMicro® M484 USB HS OTG Series LQFP 64-pin Diagram.....             | 61  |
| Figure 4.1-11 NuMicro® M484 USB HS OTG Series with 2 USB LQFP 64-pin Diagram ..... | 62  |
| Figure 4.1-12 NuMicro® M484 USB HS OTG Series LQFP 128-pin Diagram .....           | 63  |
| Figure 4.1-13 NuMicro® M485 Crypto Series QFN 33-pin Diagram .....                 | 64  |
| Figure 4.1-14 NuMicro® M485 Crypto Series LQFP 48-pin Diagram .....                | 65  |
| Figure 4.1-15 NuMicro® M485 Crypto Series LQFP 64-pin Diagram .....                | 66  |
| Figure 4.1-16 NuMicro® M485 Crypto Series LQFP 128-pin Diagram .....               | 67  |
| Figure 4.1-17 NuMicro® M487 Ethernet Series LQFP 64-pin Diagram .....              | 68  |
| Figure 4.1-18 NuMicro® M487 Ethernet Series LQFP 128-pin Diagram .....             | 69  |
| Figure 4.1-19 NuMicro® M487 Ethernet Series LQFP 144-pin Diagram .....             | 70  |
| Figure 5.1-1 NuMicro® M480 Block Diagram .....                                     | 289 |
| Figure 6.1-1 Cortex®-M4 Block Diagram.....                                         | 290 |
| Figure 6.2-1 System Reset Sources .....                                            | 294 |
| Figure 6.2-2 nRESET Reset Waveform .....                                           | 296 |
| Figure 6.2-3 Power-on Reset (POR) Waveform .....                                   | 296 |
| Figure 6.2-4 Low Voltage Reset (LVR) Waveform.....                                 | 297 |
| Figure 6.2-5 Brown-out Detector (BOD) Waveform .....                               | 298 |
| Figure 6.2-6 NuMicro® M480 Power Distribution Diagram.....                         | 299 |
| Figure 6.2-7 Power Mode State Machine .....                                        | 301 |
| Figure 6.2-8 NuMicro® M480 Power Distribution Diagram.....                         | 304 |
| Figure 6.2-9 SRAM Block Diagram .....                                              | 308 |
| Figure 6.2-10 SRAM Memory Organization .....                                       | 309 |
| Figure 6.2-11 NuMicro® M480 Bus Matrix Diagram.....                                | 310 |
| Figure 6.3-1 Clock Generator Global View Diagram.....                              | 413 |
| Figure 6.3-2 Clock Generator Block Diagram .....                                   | 414 |
| Figure 6.3-3 System Clock Block Diagrams .....                                     | 415 |
| Figure 6.3-4 HXT Stop Protect Procedure .....                                      | 416 |

|                                                                           |     |
|---------------------------------------------------------------------------|-----|
| Figure 6.3-5 SysTick Clock Control Block Diagram .....                    | 416 |
| Figure 6.3-6 Clock Output Block Diagram .....                             | 417 |
| Figure 6.3-7 USB Clock Source .....                                       | 418 |
| Figure 6.3-8 HXT Clock Sources .....                                      | 419 |
| Figure 6.4-1 Flash Memory Controller Block Diagram .....                  | 469 |
| Figure 6.4-2 Data Flash Shared with APROM Examples (128/256/512 KB) ..... | 472 |
| Figure 6.4-3 SPROM Security Mode.....                                     | 479 |
| Figure 6.4-4 OTP Memory Map .....                                         | 480 |
| Figure 6.4-5 KPROM Memory Map.....                                        | 481 |
| Figure 6.4-6 Flash Memory Map .....                                       | 489 |
| Figure 6.4-7 System Memory Map with IAP Mode .....                        | 490 |
| Figure 6.4-8 LDROM with IAP Mode.....                                     | 491 |
| Figure 6.4-9 APROM with IAP Mode .....                                    | 491 |
| Figure 6.4-10 Boot Loader with IAP Mode .....                             | 492 |
| Figure 6.4-11 System Memory Map without IAP Mode .....                    | 493 |
| Figure 6.4-12 Boot Source Selection .....                                 | 494 |
| Figure 6.4-13 ISP Procedure Example .....                                 | 497 |
| Figure 6.4-14 ISP 32-bit Programming Procedure.....                       | 498 |
| Figure 6.4-15 ISP 64-bit Programming Procedure.....                       | 499 |
| Figure 6.4-16 Multi-word Programming Time .....                           | 499 |
| Figure 6.4-17 Firmware in Boot Loader for Multi-word Programming.....     | 500 |
| Figure 6.4-18 Multi-word Programming Flow .....                           | 501 |
| Figure 6.4-19 Fast Flash Programming Verification Flow .....              | 502 |
| Figure 6.4-20 Verification Flow .....                                     | 503 |
| Figure 6.4-21 Flash CRC32 Checksum Calculation .....                      | 503 |
| Figure 6.4-22 Flash Security Key Setup Flow.....                          | 506 |
| Figure 6.4-23 Key Comparison Flow.....                                    | 508 |
| Figure 6.5-1 GPIO Controller Block Diagram.....                           | 539 |
| Figure 6.5-2 Push-Pull Output.....                                        | 540 |
| Figure 6.5-3 Open-Drain Output .....                                      | 540 |
| Figure 6.5-4 Quasi-Bidirectional I/O Mode.....                            | 541 |
| Figure 6.5-5 GPIO Rising Edge Trigger Interrupt .....                     | 542 |
| Figure 6.5-6 GPIO Falling Edge Trigger Interrupt.....                     | 542 |
| Figure 6.6-1 PDMA Controller Block Diagram .....                          | 564 |
| Figure 6.6-2 Descriptor Table Entry Structure .....                       | 565 |
| Figure 6.6-3 Basic Mode Finite State Machine .....                        | 566 |
| Figure 6.6-4 Descriptor Table Link List Structure .....                   | 567 |

|                                                                                          |     |
|------------------------------------------------------------------------------------------|-----|
| Figure 6.6-5 Scatter-Gather Mode Finite State Machine .....                              | 568 |
| Figure 6.6-6 Example of Single Transfer Type and Burst Transfer Type in Basic Mode ..... | 569 |
| Figure 6.6-7 Example of PDMA Channel 0 Time-out Counter Operation.....                   | 570 |
| Figure 6.6-8 Stride Function Block Transfer .....                                        | 570 |
| Figure 6.7-1 Timer Controller Block Diagram .....                                        | 606 |
| Figure 6.7-2 Clock Source of Timer Controller .....                                      | 607 |
| Figure 6.7-3 PWM Generator Overview Block Diagram .....                                  | 608 |
| Figure 6.7-4 PWM System Clock Source Control.....                                        | 608 |
| Figure 6.7-5 PWM Counter Clock Source Control .....                                      | 609 |
| Figure 6.7-6 PWM Independent Mode Architecture Diagram .....                             | 609 |
| Figure 6.7-7 PWM Complementary Mode Architecture Diagram .....                           | 610 |
| Figure 6.7-8 Continuous Counting Mode .....                                              | 612 |
| Figure 6.7-9 External Capture Mode.....                                                  | 613 |
| Figure 6.7-10 External Reset Counter Mode .....                                          | 614 |
| Figure 6.7-11 Internal Timer Trigger .....                                               | 615 |
| Figure 6.7-12 Inter-Timer Trigger Capture Timing .....                                   | 616 |
| Figure 6.7-13 PWM Prescale Waveform in Up Count Type .....                               | 616 |
| Figure 6.7-14 PWM Up Count Type.....                                                     | 617 |
| Figure 6.7-15 PWM Down Count Type .....                                                  | 617 |
| Figure 6.7-16 PWM Up-Down Count Type .....                                               | 618 |
| Figure 6.7-17 PWM Comparator Events in Up-Down Count Type .....                          | 619 |
| Figure 6.7-18 Period Loading Mode with Up Count Type .....                               | 620 |
| Figure 6.7-19 Immediately Loading Mode with Up Count Type.....                           | 621 |
| Figure 6.7-20 PWM Pulse Generation in Up-Down Count Type .....                           | 621 |
| Figure 6.7-21 PWM Pulse Generation in Up Count Type .....                                | 622 |
| Figure 6.7-22 PWM Pulse Generation in Down Count Type .....                              | 622 |
| Figure 6.7-23 PWM 0% to 100% Duty Cycle in Up Count Type and Up-Down Count Type .....    | 623 |
| Figure 6.7-24 PWM Independent Mode Output Waveform .....                                 | 623 |
| Figure 6.7-25 PWM Complementary Mode Output Waveform .....                               | 624 |
| Figure 6.7-26 PWMx_CH0 Output Control in Independent Mode .....                          | 624 |
| Figure 6.7-27 PWMx_CH0 and PWMx_CH1 Output Control in Complementary Mode .....           | 624 |
| Figure 6.7-28 Dead-Time Insertion .....                                                  | 625 |
| Figure 6.7-29 PWM Output Mask Control Waveform .....                                     | 625 |
| Figure 6.7-30 Brake Pin Noise Filter Block Diagram .....                                 | 626 |
| Figure 6.7-31 Brake Event Block Diagram for PWMx_CH0 and PWMx_CH1.....                   | 627 |
| Figure 6.7-32 Edge Detector Brake Waveform for PWMx_CH0 and PWMx_CH1 .....               | 628 |
| Figure 6.7-33 Level Detector Brake Waveform for PWMx_CH0 and PWMx_CH1 .....              | 629 |

|                                                                                     |     |
|-------------------------------------------------------------------------------------|-----|
| Figure 6.7-34 Brake Source Block Diagram .....                                      | 630 |
| Figure 6.7-35 System Fail Brake Block Diagram .....                                 | 630 |
| Figure 6.7-36 PWMx_CH0 and PWMx_CH1 Polarity Control with Dead-Time Insertion ..... | 631 |
| Figure 6.7-37 PWM Interrupt Architecture Diagram.....                               | 632 |
| Figure 6.7-38 PWM Trigger ADC Block Diagram .....                                   | 632 |
| Figure 6.8-1 Watchdog Timer Block Diagram.....                                      | 682 |
| Figure 6.8-2 Watchdog Timer Clock Control.....                                      | 683 |
| Figure 6.8-3 Watchdog Timer Time-out Interval and Reset Period Timing .....         | 684 |
| Figure 6.9-1 WWDT Block Diagram.....                                                | 691 |
| Figure 6.9-2 WWDT Clock Control.....                                                | 691 |
| Figure 6.9-3 WWDT Reset and Reload Behavior .....                                   | 693 |
| Figure 6.9-4 WWDT Reload Counter When CNTDAT > CMPDAT .....                         | 693 |
| Figure 6.9-5 WWDT Reload Counter When WWDT_CNT < WINCMP .....                       | 694 |
| Figure 6.9-6 WWDT Interrupt and Reset Signals .....                                 | 694 |
| Figure 6.10-1 RTC Block Diagram.....                                                | 703 |
| Figure 6.10-2 Dynamic Rate Definition .....                                         | 709 |
| Figure 6.10-3 Backup I/O Control Diagram.....                                       | 711 |
| Figure 6.11-1 EPWM Generator Overview Block Diagram.....                            | 749 |
| Figure 6.11-2 EPWM Clock Source Control .....                                       | 750 |
| Figure 6.11-3 EPWM Clock Source Control .....                                       | 751 |
| Figure 6.11-4 EPWM Independent Mode Architecture Diagram .....                      | 752 |
| Figure 6.11-5 EPWM Complementary Mode Architecture Diagram .....                    | 753 |
| Figure 6.11-6 EPWM_CH0 Prescaler Waveform in Up Counter Type .....                  | 755 |
| Figure 6.11-7 EPWM Counter Waveform when Setting Clear Counter.....                 | 756 |
| Figure 6.11-8 EPWM Up Counter Type .....                                            | 756 |
| Figure 6.11-9 EPWM Down Counter Type .....                                          | 757 |
| Figure 6.11-10 EPWM Up-Down Counter Type.....                                       | 758 |
| Figure 6.11-11 EPWM Compared point Events in Up-Down Counter Type .....             | 759 |
| Figure 6.11-12 EPWM Double Buffering Illustration .....                             | 760 |
| Figure 6.11-13 Period Loading in Up-Count Mode .....                                | 761 |
| Figure 6.11-14 Immediately Loading in Up-Count Mode .....                           | 762 |
| Figure 6.11-15 Window Loading in Up-Count Mode.....                                 | 763 |
| Figure 6.11-16 Center Loading in Up-Down-Count Mode .....                           | 764 |
| Figure 6.11-17 EPWM One-shot Mode Output Waveform .....                             | 765 |
| Figure 6.11-18 EPWM Pulse Generation.....                                           | 766 |
| Figure 6.11-19 EPWM 0% to 100% Pulse Generation .....                               | 766 |
| Figure 6.11-20 EPWM Independent Mode Waveform .....                                 | 767 |

|                                                                                              |     |
|----------------------------------------------------------------------------------------------|-----|
| Figure 6.11-21 EPWM Complementary Mode Waveform.....                                         | 768 |
| Figure 6.11-22 EPWM Group Function Waveform .....                                            | 769 |
| Figure 6.11-23 EPWM SYNC_IN Noise Filter Block Diagram .....                                 | 769 |
| Figure 6.11-24 EPWM Counter Synchronous Function Block Diagram .....                         | 770 |
| Figure 6.11-25 EPWM Synchronous Function with Synchronize source from SYNC_IN Signal         | 771 |
| Figure 6.11-26 EPWMx_CH0 Output Control in Independent Mode .....                            | 771 |
| Figure 6.11-27 EPWMx_CH0 and EPWMx_CH1 Output Control in Complementary Mode .....            | 772 |
| Figure 6.11-28 Dead-Time Insertion .....                                                     | 773 |
| Figure 6.11-29 Illustration of Mask Control Waveform.....                                    | 773 |
| Figure 6.11-30 Brake Noise Filter Block Diagram.....                                         | 774 |
| Figure 6.11-31 Brake Block Diagram for EPWMx_CH0 and EPWMx_CH1 Pair .....                    | 775 |
| Figure 6.11-32 Edge Detector Waveform for EPWMx_CH0 and EPWMx_CH1 Pair.....                  | 776 |
| Figure 6.11-33 Level Detector Waveform for EPWMx_CH0 and EPWMx_CH1 Pair.....                 | 776 |
| Figure 6.11-34 Brake Source Block Diagram .....                                              | 777 |
| Figure 6.11-35 Brake System Fail Block Diagram .....                                         | 777 |
| Figure 6.11-36 EPWM LEB Function Waveform .....                                              | 778 |
| Figure 6.11-37 Initial State and Polarity Control with Rising Edge Dead-Time Insertion ..... | 779 |
| Figure 6.11-38 EPWMx_CH0 Accumulate Interrupt Waveform.....                                  | 780 |
| Figure 6.11-39 EPWMx_CH0 and EPWMx_CH1 Pair Interrupt Architecture Diagram .....             | 781 |
| Figure 6.11-40 EPWMx_CH0 and EPWMx_CH1 Pair Trigger EADC Block Diagram.....                  | 782 |
| Figure 6.11-41 EPWM Trigger EADC in Up-Down Counter Type Timing Waveform .....               | 783 |
| Figure 6.11-42 EPWM_CH0 and EPWM_CH1 Pair Trigger DAC Block Diagram.....                     | 783 |
| Figure 6.11-43 EPWM_CH0 Capture Block Diagram .....                                          | 784 |
| Figure 6.11-44 Capture Operation Waveform.....                                               | 785 |
| Figure 6.11-45 Capture PDMA Operation Waveform of Channel 0.....                             | 786 |
| Figure 6.11-46 Accumulator PDMA Function Architecture .....                                  | 787 |
| Figure 6.12-1 BPWM Generator Overview Block Diagram.....                                     | 864 |
| Figure 6.12-2 BPWM Clock Source Control .....                                                | 865 |
| Figure 6.12-3 BPWM Clock Source Control .....                                                | 865 |
| Figure 6.12-4 BPWM Independent Mode Architecture Diagram .....                               | 866 |
| Figure 6.12-5 BPWM_CH0 CLKPSC waveform .....                                                 | 868 |
| Figure 6.12-6 BPWM Counter Clear waveform .....                                              | 869 |
| Figure 6.12-7 BPWM Up Counter Type .....                                                     | 869 |
| Figure 6.12-8 BPWM Down Counter Type .....                                                   | 870 |
| Figure 6.12-9 BPWM Up-Down Counter Type.....                                                 | 870 |
| Figure 6.12-10 BPWM CMPDAT Events in Up-Down Counter Type .....                              | 871 |
| Figure 6.12-11 Period Loading Mode with Up-Counter Type .....                                | 872 |

|                                                                                                            |     |
|------------------------------------------------------------------------------------------------------------|-----|
| Figure 6.12-12 Immediately Loading Mode with Up-Counter Type .....                                         | 873 |
| Figure 6.12-13 Center Loading Mode with Up-Down-Counter Type .....                                         | 874 |
| Figure 6.12-14 BPWM Pulse Generation (Left: Asymmetric Pulse, Right: Variety Pulse) .....                  | 875 |
| Figure 6.12-15 BPWM 0% to 100% Pulse Generation (Left: Up Counter Type, Right: Up-down Counter Type) ..... | 875 |
| Figure 6.12-16 BPWM_CH0 Output Control 3 Steps.....                                                        | 876 |
| Figure 6.12-17 Mask Control Waveform Illustration.....                                                     | 877 |
| Figure 6.12-18 Initial State and Polarity Control .....                                                    | 877 |
| Figure 6.12-19 BPWM_CH0 and BPWM_CH1 Pair Interrupt Architecture Diagram.....                              | 878 |
| Figure 6.12-20 BPWM_CH0 and BPWM_CH1 Pair Trigger EADC Source Block Diagram.....                           | 879 |
| Figure 6.12-21 BPWM CH0~ CH5 Trigger EADC Block Diagram .....                                              | 879 |
| Figure 6.12-22 BPWM Trigger EADC in Up-Down Counter Type Timing Waveform .....                             | 880 |
| Figure 6.12-23 BPWM_CH0 Capture Block Diagram .....                                                        | 881 |
| Figure 6.12-24 Capture Operation Waveform.....                                                             | 882 |
| Figure 6.13-1 QEI Block Diagram .....                                                                      | 919 |
| Figure 6.13-2 QEI Clock Source Control .....                                                               | 920 |
| Figure 6.13-3 Noise Filter.....                                                                            | 921 |
| Figure 6.13-4 Noise Filter Sampling Clock Selection.....                                                   | 922 |
| Figure 6.13-5 QEA/QEB/IDX Timing Requirement through Noise Filter .....                                    | 922 |
| Figure 6.13-6 X4 Counting Mode .....                                                                       | 923 |
| Figure 6.13-7 X2 Counting Mode .....                                                                       | 924 |
| Figure 6.13-8 Compare Operation .....                                                                      | 925 |
| Figure 6.13-9 QEI_CNT Reload/Reset Control.....                                                            | 926 |
| Figure 6.13-10 Trigger Control of Capturing QEI Counter .....                                              | 926 |
| Figure 6.13-11 Capture and Latch QEI Counter .....                                                         | 927 |
| Figure 6.13-12 Quadrature Encoder Interface Interrupt Architecture Diagram .....                           | 928 |
| Figure 6.14-1 Input Capture Timer/Counter Architecture.....                                                | 940 |
| Figure 6.14-2 Input Capture Timer/Counter Clock Source Control.....                                        | 942 |
| Figure 6.14-3 Noise Filter Sampling Clock Selection.....                                                   | 943 |
| Figure 6.14-4 Input Capture Timer/Counter Function Block .....                                             | 944 |
| Figure 6.14-5 Input Capture Timer/Counter Interrupt Architecture Diagram .....                             | 946 |
| Figure 6.15-1 UART Clock Control Diagram.....                                                              | 962 |
| Figure 6.15-2 UART Block Diagram.....                                                                      | 963 |
| Figure 6.15-3 Auto-Baud Rate Measurement .....                                                             | 971 |
| Figure 6.15-4 Transmit Delay Time Operation.....                                                           | 972 |
| Figure 6.15-5 UART nCTS Wake-up Case1.....                                                                 | 973 |
| Figure 6.15-6 UART nCTS Wake-up Case2.....                                                                 | 973 |
| Figure 6.15-7 UART Data Wake-up .....                                                                      | 974 |

|                                                                                            |      |
|--------------------------------------------------------------------------------------------|------|
| Figure 6.15-8 UART Received Data FIFO reached threshold wake-up .....                      | 974  |
| Figure 6.15-9 UART RS-485 AAD Mode Address Match Wake-up.....                              | 975  |
| Figure 6.15-10 UART Received Data FIFO threshold time-out wake-up .....                    | 975  |
| Figure 6.15-11 Auto-Flow Control Block Diagram .....                                       | 979  |
| Figure 6.15-12 UART nCTS Auto-Flow Control Enabled .....                                   | 979  |
| Figure 6.15-13 UART nRTS Auto-Flow Control Enabled .....                                   | 980  |
| Figure 6.15-14 UART nRTS Auto-Flow with Software Control .....                             | 980  |
| Figure 6.15-15 IrDA Control Block Diagram .....                                            | 981  |
| Figure 6.15-16 IrDA TX/RX Timing Diagram .....                                             | 982  |
| Figure 6.15-17 Structure of LIN Frame .....                                                | 982  |
| Figure 6.15-18 Structure of LIN Byte .....                                                 | 983  |
| Figure 6.15-19 Break Detection in LIN Mode.....                                            | 985  |
| Figure 6.15-20 LIN Frame ID and Parity Format .....                                        | 985  |
| Figure 6.15-21 LIN Sync Field Measurement .....                                            | 987  |
| Figure 6.15-22 UART_BAUD Update Sequence in AR mode if SLVDUEN is 1 .....                  | 988  |
| Figure 6.15-23 UART_BAUD Update Sequence in AR mode if SLVDUEN is 0 .....                  | 988  |
| Figure 6.15-24 RS-485 nRTS Driving Level in Auto Direction Mode .....                      | 990  |
| Figure 6.15-25 RS-485 nRTS Driving Level with Software Control .....                       | 991  |
| Figure 6.15-26 Structure of RS-485 Frame .....                                             | 991  |
| Figure 6.16-1 Ethernet MAC Controller Block Diagram .....                                  | 1030 |
| Figure 6.16-2 Ethernet Frame Format .....                                                  | 1032 |
| Figure 6.16-3 RXDMA Descriptor Data Structure .....                                        | 1034 |
| Figure 6.16-4 TXDMA Descriptor Data Structure .....                                        | 1040 |
| Figure 6.17-1 SC Clock Control Diagram (7-bit Pre-scale Counter in Clock Controller) ..... | 1103 |
| Figure 6.17-2 SC Controller Block Diagram.....                                             | 1103 |
| Figure 6.17-3 SC Data Character .....                                                      | 1107 |
| Figure 6.17-4 SC Activation Sequence .....                                                 | 1109 |
| Figure 6.17-5 SC Warm Reset Sequence .....                                                 | 1110 |
| Figure 6.17-6 SC Deactivation Sequence.....                                                | 1111 |
| Figure 6.17-7 Basic Operation Flow.....                                                    | 1112 |
| Figure 6.17-8 Initial Character TS .....                                                   | 1113 |
| Figure 6.17-9 SC Error Signal.....                                                         | 1114 |
| Figure 6.17-10 Transmit Direction Block Guard Time Operation.....                          | 1117 |
| Figure 6.17-11 Receive Direction Block Guard Time Operation.....                           | 1117 |
| Figure 6.17-12 Extra Guard Time Operation .....                                            | 1117 |
| Figure 6.18-1 I <sup>2</sup> S Controller Block Diagram .....                              | 1144 |
| Table 6.18-2 Pin Configuration of I <sup>2</sup> S Controller .....                        | 1145 |

|                                                                                                                                 |      |
|---------------------------------------------------------------------------------------------------------------------------------|------|
| Figure 6.18-3 I <sup>2</sup> S Clock Control Diagram .....                                                                      | 1146 |
| Figure 6.18-4 Master Mode Interface Block Diagram .....                                                                         | 1146 |
| Figure 6.18-5 Slave Mode Interface Block Diagram .....                                                                          | 1146 |
| Figure 6.18-6 I <sup>2</sup> S Channel Width and Data Width (CHWIDTH ≤ DATWIDTH) .....                                          | 1147 |
| Figure 6.18-7 I <sup>2</sup> S Channel Width and Data Width (CHWIDTH > DATWIDTH) .....                                          | 1147 |
| Figure 6.18-8 I <sup>2</sup> S Data Format Timing Diagram (FORMAT = 0x0 ; CHWIDTH ≤ DATWIDTH) .....                             | 1148 |
| Figure 6.18-9 MSB Justified Data Format (FORMAT = 0x1 ; CHWIDTH > DATWIDTH) .....                                               | 1148 |
| Figure 6.18-10 LSB Justified Data Format (FORMAT = 0x2 ; CHWIDTH > DATWIDTH) .....                                              | 1148 |
| Figure 6.18-11 Standard PCM Audio Timing Diagram (FORMAT = 0x4 ; CHWIDTH ≤ DATWIDTH) .....                                      | 1148 |
| Figure 6.18-12 PCM with MSB Justified Data Format (FORMAT = 0x5 ; CHWIDTH > DATWIDTH) .....                                     | 1149 |
| Figure 6.18-13 PCM with LSB Justified Data Format (FORMAT = 0x6 ; CHWIDTH > DATWIDTH) .....                                     | 1149 |
| Figure 6.18-14 TDM 6-channel Audio Format with 24-bit Data in 32-bit Channel Block (PCM Standard Data Format; FORMAT=0x4) ..... | 1150 |
| Figure 6.18-15 TDM 6-channel Audio Format with 24-bit Data in 32-bit Channel Block (PCM with MSB Justified; FORMAT=0x5) .....   | 1150 |
| Figure 6.18-16 TDM 6-channel Audio Format with 24-bit Data in 32-bit Channel Block (PCM with LSB Justified; FORMAT=0x6) .....   | 1150 |
| Figure 6.18-17 I <sup>2</sup> S Interrupts .....                                                                                | 1151 |
| Figure 6.18-18 FIFO Contents for Various 2-channel Audio Modes .....                                                            | 1152 |
| Figure 6.18-19 FIFO Contents for Various 4-channel Audio Modes .....                                                            | 1153 |
| Figure 6.18-20 FIFO Contents for Various 6-channel Audio Modes (Part-1) .....                                                   | 1154 |
| Figure 6.18-21 FIFO Contents for Various 6-channel Audio Modes (Part-2) .....                                                   | 1155 |
| Figure 6.19-1 SPI Block Diagram .....                                                                                           | 1176 |
| Figure 6.19-2 SPI Peripheral Clock .....                                                                                        | 1180 |
| Figure 6.19-3 SPI Full-Duplex Master Mode Application Block Diagram .....                                                       | 1181 |
| Figure 6.19-4 SPI Full-Duplex Slave Mode Application Block Diagram .....                                                        | 1181 |
| Figure 6.19-5 32-bit in One Transaction .....                                                                                   | 1182 |
| Figure 6.19-6 Automatic Slave Selection (SSACTPOL = 0, SUSPITV > 0x2) .....                                                     | 1183 |
| Figure 6.19-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV < 0x3) .....                                                     | 1183 |
| Figure 6.19-8 Byte Reorder Function .....                                                                                       | 1184 |
| Figure 6.19-9 Timing Waveform for Byte Suspend .....                                                                            | 1184 |
| Figure 6.19-10 SPI Half-Duplex Master Mode Application Block Diagram .....                                                      | 1185 |
| Figure 6.19-11 SPI Half-Duplex Slave Mode Application Block Diagram .....                                                       | 1185 |
| Figure 6.19-12 FIFO Threshold Comparator .....                                                                                  | 1186 |
| Figure 6.19-13 Transmit FIFO Buffer Example .....                                                                               | 1187 |
| Figure 6.19-14 Receive FIFO Buffer Example .....                                                                                | 1188 |

|                                                                              |      |
|------------------------------------------------------------------------------|------|
| Figure 6.19-15 TX Underflow Event and Slave Under Run Event.....             | 1188 |
| Figure 6.19-16 Slave Mode Bit Count Error.....                               | 1189 |
| Figure 6.19-17 I <sup>2</sup> S Data Format Timing Diagram.....              | 1191 |
| Figure 6.19-18 MSB Justified Data Format Timing Diagram .....                | 1191 |
| Figure 6.19-19 PCM Mode A Timing Diagram.....                                | 1191 |
| Figure 6.19-20 PCM Mode B Timing Diagram.....                                | 1191 |
| Figure 6.19-21 FIFO Contents for Various I <sup>2</sup> S Modes .....        | 1192 |
| Figure 6.19-22 SPI Timing in Master Mode .....                               | 1193 |
| Figure 6.19-23 SPI Timing in Master Mode (Alternate Phase of SPIx_CLK) ..... | 1193 |
| Figure 6.19-24 SPI Timing in Slave Mode .....                                | 1194 |
| Figure 6.19-25 SPI Timing in Slave Mode (Alternate Phase of SPIx_CLK) .....  | 1194 |
| Figure 6.20-1 QSPI Block Diagram.....                                        | 1219 |
| Figure 6.20-2 QSPI Peripheral Clock.....                                     | 1220 |
| Figure 6.20-3 QSPI Full-Duplex Master Mode Application Block Diagram .....   | 1221 |
| Figure 6.20-4 QSPI Full-Duplex Slave Mode Application Block Diagram.....     | 1221 |
| Figure 6.20-5 32-bit in One Transaction .....                                | 1222 |
| Figure 6.20-6 Automatic Slave Selection (SSACTPOL = 0, SUSPITV > 0x2) .....  | 1223 |
| Figure 6.20-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV < 0x3) .....  | 1223 |
| Figure 6.20-8 Byte Reorder Function.....                                     | 1224 |
| Figure 6.20-9 Timing Waveform for Byte Suspend.....                          | 1224 |
| Figure 6.20-10 QSPI Half-Duplex Master Mode Application Block Diagram .....  | 1225 |
| Figure 6.20-11 QSPI Half-Duplex Slave Mode Application Block Diagram .....   | 1225 |
| Figure 6.20-12 Two-bit Transfer Mode System Architecture .....               | 1226 |
| Figure 6.20-13 Two-bit Transfer Mode Timing (Master Mode) .....              | 1227 |
| Figure 6.20-14 Bit Sequence of Dual Output Mode .....                        | 1227 |
| Figure 6.20-15 Bit Sequence of Dual Input Mode .....                         | 1228 |
| Figure 6.20-16 Bit Sequence of Quad Output Mode.....                         | 1229 |
| Figure 6.20-17 Bit Sequence of Quad Input Mode .....                         | 1229 |
| Figure 6.20-18 FIFO Threshold Comparator .....                               | 1230 |
| Figure 6.20-19 Transmit FIFO Buffer Example.....                             | 1231 |
| Figure 6.20-20 Receive FIFO Buffer Example .....                             | 1232 |
| Figure 6.20-21 TX Underflow Event and Slave Under Run Event.....             | 1232 |
| Figure 6.20-22 Two-bit Transfer Mode FIFO Buffer Example .....               | 1233 |
| Figure 6.20-23 TX Underflow Event (QSPI0 Slave 3-Wire Mode Enabled).....     | 1233 |
| Figure 6.20-24 Slave Mode Bit Count Error.....                               | 1234 |
| Figure 6.20-25 Slave Time-out Event .....                                    | 1234 |
| Figure 6.20-26 QSPI Timing in Master Mode .....                              | 1236 |

|                                                                                                    |      |
|----------------------------------------------------------------------------------------------------|------|
| Figure 6.20-27 QSPI Timing in Master Mode (Alternate Phase of QSPIx_CLK).....                      | 1237 |
| Figure 6.20-28 QSPI Timing in Slave Mode .....                                                     | 1237 |
| Figure 6.20-29 QSPI Timing in Slave Mode (Alternate Phase of QSPIx_CLK).....                       | 1238 |
| Figure 6.21-1 SPIM Block Diagram.....                                                              | 1258 |
| Figure 6.21-2 SPIM Timing Diagram.....                                                             | 1259 |
| Figure 6.21-3 TYPE_1 Program Command Flow with Quad Mode Write .....                               | 1261 |
| Figure 6.21-4 TYPE_2 Program Command Flow with Quad Mode Write .....                               | 1262 |
| Figure 6.21-5 TYPE_3 Program Command Flow with Quad Mode Write .....                               | 1263 |
| Figure 6.21-6 Fast Read Quad I/O Command 0xEB with Continuous Read Mode Disable.....               | 1264 |
| Figure 6.21-7 Fast Read Quad I/O Command 0xEB with Continuous Read Mode Enable .....               | 1264 |
| Figure 6.21-8 DTR/DDR Fast read command 0x0D .....                                                 | 1267 |
| Figure 6.21-9 DTR/DDR Fast Read Dual I/O Command 0xBD .....                                        | 1267 |
| Figure 6.21-10 DTR/DDR Fast Read Quad I/O Command 0xED.....                                        | 1268 |
| Figure 6.21-11 SPIM_SS Active Setup Time Relative to SPIM_CLK, and SPIM_SS Deselect Time .....     | 1287 |
| Figure 6.22-1 I <sup>2</sup> C Controller Block Diagram.....                                       | 1291 |
| Figure 6.22-2 I <sup>2</sup> C Bus Timing .....                                                    | 1293 |
| Figure 6.22-3 I <sup>2</sup> C Protocol.....                                                       | 1294 |
| Figure 6.22-4 START and STOP Conditions .....                                                      | 1294 |
| Figure 6.22-5 Bit Transfer on the I <sup>2</sup> C Bus .....                                       | 1295 |
| Figure 6.22-6 Acknowledge on the I <sup>2</sup> C Bus .....                                        | 1295 |
| Figure 6.22-7 Master Transmits Data to Slave by 7-bit .....                                        | 1296 |
| Figure 6.22-8 Master Reads Data from Slave by 7-bit.....                                           | 1296 |
| Figure 6.22-9 Master Transmits Data to Slave by 10-bit .....                                       | 1296 |
| Figure 6.22-10 Master Reads Data from Slave by 10-bit .....                                        | 1297 |
| Figure 6.22-11 Control I <sup>2</sup> C Bus according to the Current I <sup>2</sup> C Status ..... | 1297 |
| Figure 6.22-12 Master Transmitter Mode Control Flow .....                                          | 1298 |
| Figure 6.22-13 Master Receiver Mode Control Flow .....                                             | 1299 |
| Figure 6.22-14 Slave Mode Control Flow .....                                                       | 1300 |
| Figure 6.22-15 GC Mode .....                                                                       | 1301 |
| Figure 6.22-16 Arbitration Lost.....                                                               | 1302 |
| Figure 6.22-17 Bus Management Packet Protocol Diagram Element Key .....                            | 1304 |
| Figure 6.22-187-bit Addressable Device to Host Communication .....                                 | 1305 |
| Figure 6.22-197-bit Addressable Device Responds to an ARA.....                                     | 1305 |
| Figure 6.22-20 Bus Management ALERT function .....                                                 | 1306 |
| Figure 6.22-21 Bus Management Time Out Timing.....                                                 | 1307 |
| Figure 6.22-22 Bus Clock Low Time Out Timing .....                                                 | 1307 |
| Figure 6.22-23 Setup Time Wrong Adjustment.....                                                    | 1309 |

|                                                                                       |      |
|---------------------------------------------------------------------------------------|------|
| Figure 6.22-24 Hold Time Wrong Adjustment.....                                        | 1309 |
| Figure 6.22-25 I <sup>2</sup> C Data Shifting Direction .....                         | 1310 |
| Figure 6.22-26 I <sup>2</sup> C Time-out Count Block Diagram .....                    | 1312 |
| Figure 6.22-27 I <sup>2</sup> C Wake-Up Related Signals Waveform .....                | 1313 |
| Figure 6.22-28 EEPROM Random Read .....                                               | 1314 |
| Figure 6.22-29 Protocol of EEPROM Random Read.....                                    | 1315 |
| Figure 6.23-1 USCI Block Diagram.....                                                 | 1339 |
| Figure 6.23-2 Input Conditioning for USCIx_DAT[1:0] and USCIx_CTL[1:0] .....          | 1340 |
| Figure 6.23-3 Input Conditioning for USCIx_CLK .....                                  | 1341 |
| Figure 6.23-4 Block Diagram of Data Buffering .....                                   | 1342 |
| Figure 6.23-5 Data Access Structure .....                                             | 1343 |
| Figure 6.23-6 Transmit Data Path.....                                                 | 1343 |
| Figure 6.23-7 Receive Data Path.....                                                  | 1344 |
| Figure 6.23-8 Protocol-Relative Clock Generator .....                                 | 1345 |
| Figure 6.23-9 Basic Clock Divider Counter .....                                       | 1346 |
| Figure 6.23-10 Block of Timing Measurement Counter .....                              | 1346 |
| Figure 6.23-11 Sample Time Counter.....                                               | 1347 |
| Figure 6.23-12 Event and Interrupt Structure .....                                    | 1348 |
| Figure 6.24-1 USCI-UART Mode Block Diagram.....                                       | 1350 |
| Figure 6.24-2 UART Signal Connection for Full-Duplex Communication.....               | 1352 |
| Figure 6.24-3 UART Standard Frame Format .....                                        | 1353 |
| Figure 6.24-4 UART Bit Timing (data sample time) .....                                | 1355 |
| Figure 6.24-5 UART Auto Baud Rate Control.....                                        | 1357 |
| Figure 6.24-6 Incoming Data Wake-Up .....                                             | 1358 |
| Figure 6.24-7 nCTS Wake-Up Case 1 .....                                               | 1358 |
| Figure 6.24-8 nCTS Wake-Up Case 2 .....                                               | 1358 |
| Figure 6.25-1 SPI Master Mode Application Block Diagram.....                          | 1384 |
| Figure 6.25-2 SPI Slave Mode Application Block Diagram.....                           | 1384 |
| Figure 6.25-3 USCI SPI Mode Block Diagram .....                                       | 1385 |
| Figure 6.25-44-Wire Full-Duplex SPI Communication Signals (Master Mode).....          | 1387 |
| Figure 6.25-54-Wire Full-Duplex SPI Communication Signals (Slave Mode).....           | 1388 |
| Figure 6.25-6 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x0) | 1389 |
| Figure 6.25-7 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x1) | 1389 |
| Figure 6.25-8 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x2) | 1390 |
| Figure 6.25-9 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x3) | 1390 |
| Figure 6.25-1016-bit Data Length in One Word Transaction with MSB First Format .....  | 1391 |
| Figure 6.25-11 Word Suspend Interval between Two Transaction Words .....              | 1391 |

|                                                                                               |      |
|-----------------------------------------------------------------------------------------------|------|
| Figure 6.25-12 Auto Slave Select (SUSPITV $\geq$ 0x3) .....                                   | 1392 |
| Figure 6.25-13 Auto Slave Select (SUSPITV < 0x3) .....                                        | 1393 |
| Figure 6.25-14 One Output Data Channel Half-duplex (SPI Master Mode) .....                    | 1394 |
| Figure 6.25-15 One Input Data Channel Half-duplex (SPI Master Mode) .....                     | 1394 |
| Figure 6.25-16 SPI Timing in Master Mode .....                                                | 1396 |
| Figure 6.25-17 SPI Timing in Master Mode (Alternate Phase of Serial Bus Clock) .....          | 1396 |
| Figure 6.25-18 SPI Timing in Slave Mode .....                                                 | 1397 |
| Figure 6.25-19 SPI Timing in Slave Mode (Alternate Phase of Serial Bus Clock) .....           | 1397 |
| Figure 6.26-1 I <sup>2</sup> C Bus Timing .....                                               | 1424 |
| Figure 6.26-2 USCI I <sup>2</sup> C Mode Block Diagram .....                                  | 1425 |
| Figure 6.26-3 I <sup>2</sup> C Protocol .....                                                 | 1426 |
| Figure 6.26-4 START and STOP Conditions .....                                                 | 1427 |
| Figure 6.26-5 Bit Transfer on the I <sup>2</sup> C Bus .....                                  | 1428 |
| Figure 6.26-6 Acknowledge on the I <sup>2</sup> C Bus .....                                   | 1428 |
| Figure 6.26-7 Arbitration Lost .....                                                          | 1430 |
| Figure 6.26-8 Control I <sup>2</sup> C Bus according to Current I <sup>2</sup> C Status ..... | 1432 |
| Figure 6.26-9 Master Transmits Data to Slave with a 7-bit Address .....                       | 1432 |
| Figure 6.26-10 Master Reads Data from Slave with a 7-bit Address .....                        | 1432 |
| Figure 6.26-11 Master Transmits Data to Slave by 10-bit Address .....                         | 1433 |
| Figure 6.26-12 Master Reads Data from Slave by 10-bit Address .....                           | 1433 |
| Figure 6.26-13 Master Transmitter Mode Control Flow with 7-bit Address .....                  | 1434 |
| Figure 6.26-14 Master Receiver Mode Control Flow with 7-bit Address .....                     | 1435 |
| Figure 6.26-15 Master Transmitter Mode Control Flow with 10-bit Address .....                 | 1436 |
| Figure 6.26-16 Master Recevier Mode Control Flow with 10-bit Address .....                    | 1437 |
| Figure 6.26-17 Save Mode Control Flow with 7-bit Address .....                                | 1438 |
| Figure 6.26-18 Save Mode Control Flow with 10-bit Address .....                               | 1439 |
| Figure 6.26-19 GC Mode with 7-bit Address .....                                               | 1440 |
| Figure 6.26-20 Setup Time Wrong Adjustment .....                                              | 1442 |
| Figure 6.26-21 Hold Time Wrong Adjustment .....                                               | 1442 |
| Figure 6.26-22 I <sup>2</sup> C Time-out Count Block Diagram .....                            | 1443 |
| Figure 6.26-23 EEPROM Random Read .....                                                       | 1444 |
| Figure 6.26-24 Protocol of EEPROM Random Read .....                                           | 1444 |
| Figure 6.27-1 CAN Peripheral Block Diagram .....                                              | 1465 |
| Figure 6.27-2 CAN Core in Silent Mode .....                                                   | 1468 |
| Figure 6.27-3 CAN Core in Loop Back Mode .....                                                | 1468 |
| Figure 6.27-4 CAN Core in Loop Back Mode Combined with Silent Mode .....                      | 1469 |
| Figure 6.27-5 Data transfer between IFn Registers and Message .....                           | 1471 |

|                                                                                            |      |
|--------------------------------------------------------------------------------------------|------|
| Figure 6.27-6 Application Software Handling of a FIFO Buffer.....                          | 1476 |
| Figure 6.27-7 Bit Timing.....                                                              | 1478 |
| Figure 6.27-8 Propagation Time Segment.....                                                | 1479 |
| Figure 6.27-9 Synchronization on “late” and “early” Edges .....                            | 1481 |
| Figure 6.27-10 Filtering of Short Dominant Spikes .....                                    | 1482 |
| Figure 6.27-11 Structure of the CAN Core’s CAN Protocol Controller .....                   | 1483 |
| Figure 6.28-1 SD Host Controller Block Diagram .....                                       | 1527 |
| Figure 6.28-2 PAD (Physical Address Descriptor) Table Format .....                         | 1530 |
| Figure 6.29-1 EBI Block Diagram.....                                                       | 1552 |
| Figure 6.29-2 Connection of 16-bit EBI Data Width with 16-bit Device .....                 | 1555 |
| Figure 6.29-3 Connection of 8-bit EBI Data Width with 8-bit Device .....                   | 1555 |
| Figure 6.29-4 Connection of 16-bit EBI Data Width with 16-bit Device in Separate mode..... | 1556 |
| Figure 6.29-5 Connection of 8-bit EBI Data Width with 8-bit Device in Separate mode.....   | 1556 |
| Figure 6.29-6 Timing Control Waveform for 16-bit Data Width.....                           | 1558 |
| Figure 6.29-7 Timing Control Waveform for 8-bit Data Width.....                            | 1559 |
| Figure 6.29-8 Timing Control Waveform for Byte Write in 16-bit Data Mode .....             | 1560 |
| Figure 6.29-9 Timing Control Waveform for Insert Idle Cycle.....                           | 1561 |
| Figure 6.29-10 Timing Control Waveform for 16-bit Data Width for Separate Mode.....        | 1562 |
| Figure 6.29-11 Timing Control Waveform for Continuous Data Access Mode .....               | 1563 |
| Figure 6.30-1 USB Block Diagram .....                                                      | 1570 |
| Figure 6.30-2 NEVWK Interrupt Operation Flow.....                                          | 1572 |
| Figure 6.30-3 Endpoint SRAM Structure .....                                                | 1573 |
| Figure 6.30-4 Setup Transaction Followed by Data IN Transaction .....                      | 1574 |
| Figure 6.30-5 Data Out Transfer.....                                                       | 1574 |
| Figure 6.30-6 LPM State Transition Diagram .....                                           | 1575 |
| Figure 6.31-1 USB Device Controller Block Diagram .....                                    | 1603 |
| Figure 6.32-1 USB 2.0 FS Host Controller Block Diagram .....                               | 1662 |
| Figure 6.33-1 USB OTG Block Diagram .....                                                  | 1718 |
| Figure 6.33-2 USB Device Mode .....                                                        | 1719 |
| Figure 6.33-3 USB Host Mode .....                                                          | 1720 |
| Figure 6.34-1 USB OTG Block Diagram .....                                                  | 1733 |
| Figure 6.34-2 USB Device Mode .....                                                        | 1734 |
| Figure 6.34-3 USB Host Mode .....                                                          | 1734 |
| Figure 6.35-1 CRC Generator Block Diagram .....                                            | 1747 |
| Figure 6.35-2 CHECKSUM Bit Order Reverse Functional Block.....                             | 1748 |
| Figure 6.35-3 Write Data Bit Order Reverse Functional Block .....                          | 1749 |
| Figure 6.36-1 Cryptographic Accelerator Block Diagram.....                                 | 1757 |

|                                                                                  |      |
|----------------------------------------------------------------------------------|------|
| Figure 6.36-2 PRNG Function Diagram .....                                        | 1760 |
| Figure 6.36-3 Electronic Codebook Mode .....                                     | 1761 |
| Figure 6.36-4 Cipher Block Chaining Mode .....                                   | 1762 |
| Figure 6.36-5 Cipher Feedback Mode .....                                         | 1763 |
| Figure 6.36-6 Output Feedback Mode .....                                         | 1764 |
| Figure 6.36-7 Counter Mode .....                                                 | 1765 |
| Figure 6.36-8 CBC-CS1 Encryption .....                                           | 1765 |
| Figure 6.36-9 CBC-CS1 Decryption .....                                           | 1766 |
| Figure 6.37-1 ADC Converter Block Diagram .....                                  | 1859 |
| Figure 6.37-2 Sample Module 0~3 Block Diagram .....                              | 1861 |
| Figure 6.37-3 Sample Module 4~15 Block Diagram .....                             | 1862 |
| Figure 6.37-4 Sample Module 16~18 Block Diagram .....                            | 1862 |
| Figure 6.37-5 EADC Clock Control .....                                           | 1863 |
| Figure 6.37-6 Example ADC Conversion Timing Diagram, n=0~18 .....                | 1864 |
| Figure 6.37-7 Sample Module Conversion Priority Arbitrator Diagram .....         | 1865 |
| Figure 6.37-8 Specific Sample Module ADC EOC Signal for ADINT0~3 Interrupt ..... | 1867 |
| Figure 6.37-9 EPWM-triggered ADC Start Conversion .....                          | 1867 |
| Figure 6.37-10 External triggered ADC Start Conversion .....                     | 1868 |
| Figure 6.37-11 Conversion Start Delay Timing Diagram .....                       | 1869 |
| Figure 6.37-12 EADC0_ST De-bounce Timing Diagram .....                           | 1869 |
| Figure 6.37-13 ADC Extend Sampling Timing Diagram .....                          | 1870 |
| Figure 6.37-14 ADC Conversion Result Monitor Logics Diagram .....                | 1871 |
| Figure 6.37-15 ADC Controller Interrupts .....                                   | 1872 |
| Figure 6.37-16 ADC Start up Sequence with Calibration .....                      | 1873 |
| Figure 6.38-1 Digital-to-Analog Converter Block Diagram .....                    | 1909 |
| Figure 6.38-2 Data Holding Register Format .....                                 | 1911 |
| Figure 6.38-3 DAC Conversion Started by Software Write Trigger .....             | 1911 |
| Figure 6.38-4 DAC Conversion Started by Hardware Trigger Event .....             | 1912 |
| Figure 6.38-5 DAC0 and DAC1 Group and Ungroup Update Example .....               | 1912 |
| Figure 6.38-6 DAC PDMA Under-Run Condition Example .....                         | 1913 |
| Figure 6.38-7 DAC Continuous Conversion with Software PDMA Mode .....            | 1913 |
| Figure 6.38-8 DAC Interrupt Source .....                                         | 1914 |
| Figure 6.39-1 Analog Comparator Block Diagram .....                              | 1931 |
| Figure 6.39-2 Comparator Hysteresis Function of ACMP0 .....                      | 1932 |
| Figure 6.39-3 Window Latch Mode .....                                            | 1933 |
| Figure 6.39-4 An example of filter function .....                                | 1933 |
| Figure 6.39-5 Comparator Controller Interrupt .....                              | 1934 |

|                                                                |      |
|----------------------------------------------------------------|------|
| Figure 6.39-6 Comparator Reference Voltage Block Diagram ..... | 1934 |
| Figure 6.39-7 Example of Window Compare Mode .....             | 1935 |
| Figure 6.39-8 Example of Window Compare Mode .....             | 1936 |
| Figure 6.40-1 OP Amplifier Block Diagram .....                 | 1946 |

## List of Tables

|                                                                               |     |
|-------------------------------------------------------------------------------|-----|
| Table 6.2-1 Reset Value of Registers .....                                    | 295 |
| Table 6.2-2 Power Mode Table .....                                            | 300 |
| Table 6.2-3 Power Mode Difference Table .....                                 | 301 |
| Table 6.2-4 Power Mode Definition Table .....                                 | 301 |
| Table 6.2-5 Clocks in Power Modes .....                                       | 302 |
| Table 6.2-6 Re-Entering Power-down Mode Condition .....                       | 304 |
| Table 6.2-7 Address Space Assignments for On-Chip Controllers.....            | 307 |
| Table 6.2-8 SRAM Organization .....                                           | 308 |
| Table 6.2-9 Exception Model .....                                             | 374 |
| Table 6.2-10 Interrupt Number Table.....                                      | 377 |
| Table 6.2-11 Priority Grouping .....                                          | 407 |
| Table 6.3-1 Symbol definition of PLL Output Frequency formula .....           | 446 |
| Table 6.4-1 Dual-Bank Block Address Range .....                               | 471 |
| Table 6.4-2 Vector Mapping Support .....                                      | 494 |
| Table 6.4-3 ISP Command List .....                                            | 496 |
| Table 6.4-4 FMC Control Registers for Flash Programming .....                 | 498 |
| Table 6.4-5 Lock Effect Table with Four Protections for CPU .....             | 509 |
| Table 6.4-6 Lock Effect Table with Four Protections for ICE/ ICP/Writer ..... | 509 |
| Table 6.6-1 Channel Priority Table .....                                      | 566 |
| Table 6.7-1 TIMER01 Pin Configuration .....                                   | 610 |
| Table 6.7-2 TIMER23 Pin Configuration .....                                   | 611 |
| Table 6.7-3 PWM Pulse Generation Event Priority in Up Count Type.....         | 622 |
| Table 6.7-4 PWM Pulse Generation Event Priority in Down Count Type .....      | 623 |
| Table 6.7-5 PWM Pulse Generation Event Priority in Up-Down Count Type .....   | 623 |
| Table 6.8-1 Watchdog Timer Time-out Interval Period Selection .....           | 684 |
| Table 6.9-1 WWDT Prescaler Value Selection .....                              | 692 |
| Table 6.9-2 CMPDAT Setting Limitation .....                                   | 695 |
| Table 6.10-1 RTC Read/Write Enable .....                                      | 706 |
| Table 6.10-2 12/24 Hour Time Scale Selection .....                            | 707 |
| Table 6.10-3 Registers Value after Powered On .....                           | 708 |
| Table 6.10-4 Registers Power Domain .....                                     | 708 |
| Table 6.10-5 Dynamic Pattern Source Selection .....                           | 709 |
| Table 6.10-6 Tamper Control Bit Effect for Pair 0 .....                       | 709 |
| Table 6.10-7 Tamper Control Bit Effect for Pair 1 and 2 .....                 | 710 |
| Table 6.11-1 EPWM Clock Source Control Registers Setting Table .....          | 750 |
| Table 6.11-2 EPWM Pulse Generation Event Priority for Up-Counter .....        | 767 |

|                                                                              |      |
|------------------------------------------------------------------------------|------|
| Table 6.11-3 EPWM Pulse Generation Event Priority for Down-Counter.....      | 767  |
| Table 6.11-4 EPWM Pulse Generation Event Priority for Up-Down-Counter .....  | 767  |
| Table 6.12-1 BPWM Clock Source Control Registers Setting Table .....         | 866  |
| Table 6.12-2 BPWM Pulse Generation Event Priority for Up-Counter .....       | 875  |
| Table 6.12-3 BPWM Pulse Generation Event Priority for Down-Counter.....      | 876  |
| Table 6.12-4 BPWM Pulse Generation Event Priority for Up-Down-Counter .....  | 876  |
| Table 6.13-1 Direction of Counting .....                                     | 925  |
| Table 6.14-1 Typical Case of Noise Filter Settings.....                      | 942  |
| Table 6.15-1 NuMicro® M480 Series UART Features .....                        | 961  |
| Table 6.15-2 UART Interrupt.....                                             | 964  |
| Table 6.15-3 UART Interface Controller Pin .....                             | 968  |
| Table 6.15-4 UART controller Baud Rate Equation Table .....                  | 969  |
| Table 6.15-5 UART controller Baud Rate Parameter Setting Example Table ..... | 969  |
| Table 6.15-6 UART controller Baud Rate Register Setting Example Table .....  | 969  |
| Table 6.15-7 Baud Rate Compensation Example Table 1 .....                    | 970  |
| Table 6.15-8 Baud Rate Compensation Example Table 2 .....                    | 971  |
| Table 6.15-9 UART controller Interrupt Source and Flag List.....             | 977  |
| Table 6.15-10 UART Line Control of Word and Stop Length Setting .....        | 978  |
| Table 6.15-11 UART Line Control of Parity Bit Setting .....                  | 978  |
| Table 6.15-12 LIN Header Selection in Master Mode.....                       | 983  |
| Table 6.16-1 Arbiter Arbitration Results .....                               | 1031 |
| Table 6.16-2 64-bit Reference Timing Counter.....                            | 1033 |
| Table 6.16-3 RXDMA Descriptor Word 1 (TSEN (EMAC_TSCTL[0]) is 0).....        | 1037 |
| Table 6.16-4 RXDMA Descriptor Word 1 (TSEN (EMAC_TSCTL[0]) is 1).....        | 1037 |
| Table 6.16-5 RXDMA Descriptor Word 2.....                                    | 1038 |
| Table 6.16-6 RXDMA Descriptor Word 3 (TSEN (EMAC_TSCTL[0]) is 0).....        | 1039 |
| Table 6.16-7 RXDMA Descriptor Word 3 (TSEN (EMAC_TSCTL[0]) is 1).....        | 1039 |
| Table 6.16-8 TXDMA Descriptor Word 0 .....                                   | 1042 |
| Table 6.16-9 TXDMA Descriptor Word 1 (TSEN (EMAC_TSCTL[0]) is 0) .....       | 1043 |
| Table 6.16-10 TXDMA Descriptor Word 1 (TSEN (EMAC_TSCTL[0]) is 1) .....      | 1043 |
| Table 6.16-11 TXDMA Descriptor Word 2 .....                                  | 1045 |
| Table 6.16-12 TXDMA Descriptor Word 3 (TSEN (EMAC_TSCTL[0]) is 0) .....      | 1046 |
| Table 6.16-13 TXDMA Descriptor Word 3 (TSEN (EMAC_TSCTL[0]) is 1) .....      | 1046 |
| Table 6.16-14 Different CAMCMR Setting and Type of Received Packet.....      | 1052 |
| Table 6.16-15 MII Management Frame Format .....                              | 1067 |
| Table 6.16-16 MII Management Function Configure Sequence .....               | 1067 |
| Table 6.17-1 SC Host Controller Pin Description.....                         | 1104 |

|                                                                                               |      |
|-----------------------------------------------------------------------------------------------|------|
| Table 6.17-2 UART Pin Description .....                                                       | 1104 |
| Table 6.17-3 Timer0/Timer1/Timer2 Operation Mode .....                                        | 1117 |
| Table 6.19-1 SPI/I <sup>2</sup> S Interface Controller Pin Description (SPI0~SPI3) .....      | 1180 |
| Table 6.21-1 Mapping Address for SPI Flash Controller in AMBA System .....                    | 1269 |
| Table 6.21-2 Function Description for Slave Select Active Level and Slave Active Enable ..... | 1276 |
| Table 6.22-1 Reserved SMBus Address.....                                                      | 1303 |
| Table 6.22-2 Relationship between I <sup>2</sup> C Baud Rate and PCLK .....                   | 1308 |
| Table 6.22-3 I <sup>2</sup> C Status Code Description .....                                   | 1311 |
| Table 6.23-1 Input Signals for Different Protocols .....                                      | 1340 |
| Table 6.23-2 Output Signals for Different Protocols .....                                     | 1341 |
| Table 6.23-3 Data Transfer Events and Interrupt Handling .....                                | 1348 |
| Table 6.23-4 Protocol-specific Events and Interrupt Handling.....                             | 1349 |
| Table 6.24-1 Input Signals for UART Protocol .....                                            | 1353 |
| Table 6.24-2 Output Signals for Different Protocol .....                                      | 1353 |
| Table 6.25-1 Serial Bus Clock Configuration .....                                             | 1388 |
| Table 6.26-1 Relationship between I <sup>2</sup> C Baud Rate and PCLK .....                   | 1442 |
| Table 6.27-1 Initialization of a Transmit Object.....                                         | 1473 |
| Table 6.27-2 Initialization of a Receive Object.....                                          | 1474 |
| Table 6.27-3 CAN Bit Time Parameters .....                                                    | 1478 |
| Table 6.27-4 CAN Register Map for Each Bit Function .....                                     | 1490 |
| Table 6.27-5 Last Error Code.....                                                             | 1495 |
| Table 6.27-6 Source of Interrupts .....                                                       | 1498 |
| Table 6.27-7 IF1 and IF2 Message Interface Register .....                                     | 1501 |
| Table 6.27-8 Structure of a Message Object in the Message Memory.....                         | 1515 |
| Table 6.28-1 SD0 Pin Configuration .....                                                      | 1528 |
| Table 6.28-2 SD1 Pin Configuration .....                                                      | 1528 |
| Table 6.29-1 EBI Address Mapping .....                                                        | 1554 |
| Table 6.29-2 Timing Control Parameter.....                                                    | 1557 |
| Table 6.30-1 USB Link Power Manager (Lx) States .....                                         | 1575 |
| Table 6.31-1 Scatter Gather Descriptor Format.....                                            | 1605 |
| Table 6.36-1 Each Engine Error Conditions and Error Flag .....                                | 1758 |
| Table 6.36-2 DMA Enable Bit Table.....                                                        | 1759 |
| Table 6.36-3 DMA Cascade Bit Table.....                                                       | 1759 |
| Table 6.36-4 Channel Selection Bit Table .....                                                | 1759 |
| Table 6.36-5 ECC Parameters and Corresponding Registers Table .....                           | 1771 |
| Table 6.36-6 Required Input Data of Various Operations.....                                   | 1771 |
| Table 6.36-7 Low-Weight Binary Irreducible Polynomials .....                                  | 1775 |

|                                                                      |      |
|----------------------------------------------------------------------|------|
| Table 6.37-1 Relation between Resolution and Conversion Cycles ..... | 1865 |
| Table 6.37-2 EADC Differential Model Channel Selection .....         | 1871 |
| Table 6.37-3 EADC Power Saving Mode .....                            | 1873 |
| Table 6.37-4 EADC Start up with Calibration .....                    | 1873 |
| Table 6.39-1 Truth Table of Window Compare Logic .....               | 1935 |
| Table 10.1-1 List of Abbreviations.....                              | 1969 |

## 1 GENERAL DESCRIPTION

The NuMicro® M480 series 32-bit microcontroller powered by Arm® Cortex®-M4F with DSP extension runs up to 192 MHz with 175 $\mu$ A/MHz power consumption. Its 256/512 KB embedded Flash memory in dual-bank architecture supports Over-The-Air firmware upgrade. The 96/160 KB embedded SRAM includes 32 KB cache for speeding up code execution from the external SPI Flash. Built-in 4 KB Secure Protection ROM provides a safe space for saving confidential program or data. System supports a wide voltage range from 1.8V to 3.63V in industrial operating temperature from -40°C to 105°C.

The M480 series is equipped with a large number of high speed digital peripherals, such as a USB 2.0 high speed interface with on-chip transceiver working in device/host/OTG mode, a USB 2.0 full speed interface with on-chip transceiver working in device/host/OTG mode, up to nine UART interfaces including three ISO-7816-3 interfaces, up to four composite SPI/I2S interfaces, a Quad-SPI interface, a SPI Flash interface supporting quad mode, three I<sup>2</sup>C interfaces, a 192 kHz/32-bit I<sup>2</sup>S interface, two SDIO interfaces, two CAN 2.0B interfaces, two QEI interfaces, a 10/100 Mbps Ethernet MAC supporting RMII and two Universal Serial Control Interfaces which can be configured as UART, SPI or I<sup>2</sup>C. The M480 series also supports 16 channels peripheral DMA and up to 32 channels PWM running up to 192 MHz.

The M480 series provides high performance analog peripherals, such as a 12-bit 5MSPS SAR ADC with up to 16 channels, two 12-bit 1MSPS DAC, two analog comparators and three operational amplifiers, as well as a built-in hardware cryptography accelerator that supports ECC, AES, DES, triple DES, SHA, HMAC and a random number generator (RNG).

The NuMicro® M480 series includes the following sub-series:

- NuMicro® M481 Base series: Delivers high performance computing power with low power consumption for running complex algorithm.
- NuMicro® M482 USB FS OTG series: Built-in USB 2.0 full speed interface with on-chip OTG transceiver working in device/host/OTG mode.
- NuMicro® M483 CAN series: Built-in two sets of CAN 2.0B bus interfaces.
- NuMicro® M484 USB HS OTG series: Built-in USB 2.0 high speed interface with on-chip OTG transceiver working in device/host/OTG mode.
- NuMicro® M485 Crypto series: Built-in hardware cryptography engine and random number generator.
- NuMicro® M487 Ethernet series: Built-in 10/100Mbps Ethernet MAC supports industrial RMII, MDC and MDIO for communicating with an external transceiver.

## 2 FEATURE DESCRIPTION

### *Core and System*

#### **Boot Loader**

- Factory pre-loaded 32 KB mask ROM for secure boot procedure
- Uses SHA-256 and AES-256 to validate data in APROM, LDROM and external SPI Flash
- Nuvoton ISP (In-System-Programming) tool for firmware upgrade via UART and high speed USB device
- ISP/IAP libraries

#### **ARM® Cortex®-M4**

- ARM® Cortex®-M4 processor, running up to 192 MHz
- Built-in Memory Protection Unit (MPU)
- Built-in Nested Vectored Interrupt Controller (NVIC)
- Hardware IEEE 754 compliant Floating-point Unit (FPU)
- DSP extension with hardware divider and single-cycle 32-bit hardware multiplier
- 24-bit system tick timer
- Programmable and maskable interrupt
- Low Power Sleep mode by WFI and WFE instructions

#### **Brown-out Detector (BOD)**

- Eight-level BOD with brown-out interrupt and reset option. (3.0V/2.8V/2.6V/2.4V/2.2V/2.0V/1.8V/1.6V)

#### **Low Voltage Reset (LVR)**

- LVR with 1.5V threshold voltage level.

#### **Security**

- 96-bit Unique ID (UID).
- 128-bit Unique Customer ID (UCID).
- One built-in temperature sensor with 1°C resolution.

### **Memories**

#### **Flash**

- Dual bank 512/256 KB on-chip Application ROM (APROM) for Over-The-Air (OTA) upgrade
- 192 MHz maximum frequency, with performance at zero wait cycle in continuous address read access
- 4 KB on-chip Flash for user-defined loader (LDROM)
- 8 KB non-readable Key Protection ROM (KPROM) for firmware programming protection
- 4 KB non-readable Security Protection ROM (SPROM) for intellectual property protection
- 2 KB One Time Programmable (OTP) ROM for data security
- All on-chip Flash support 4 KB page erase
- Fast Flash programming verification with CRC
- On-chip Flash programming with In-Chip Programming (ICP), In-System Programming (ISP) and In-Application Programming (IAP)

|                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            | <p>capabilities</p> <ul style="list-style-type: none"><li>Configurable boot up sources including user-defined loader (LDROM) or Application ROM (APROM)</li><li>Data Flash with configurable memory size</li><li>2-wired ICP Flash updating through SWD interface</li><li>32-bit/64-bit and multi-word Flash programming function</li></ul>                                                                                                                                                                                                                                                          |
| <b>SRAM</b>                                | <ul style="list-style-type: none"><li>Up to 160 KB on-chip SRAM includes:<ul style="list-style-type: none"><li>32 KB SRAM located in bank 0 that supports hardware parity check and retention mode; Exception (NMI) generated upon a parity check error</li><li>96/32 KB SRAM located in bank 1</li><li>32 KB SRAM located in bank 2 that can be used as cache for external SPI Flash memory</li></ul></li><li>Byte-, half-word- and word-access</li><li>PDMA operation</li></ul>                                                                                                                    |
| <b>Cyclic Redundancy Calculation (CRC)</b> | <ul style="list-style-type: none"><li>Supports CRC-CCITT, CRC-8, CRC-16 and CRC-32 polynomials</li><li>Programmable initial value and seed value</li><li>Programmable order reverse setting and one's complement setting for input data and CRC checksum</li><li>8-bit, 16-bit, and 32-bit data width</li><li>8-bit write mode with 1-AHB clock cycle operation</li><li>16-bit write mode with 2-AHB clock cycle operation</li><li>32-bit write mode with 4-AHB clock cycle operation</li><li>Uses DMA to write data with performing CRC operation</li></ul>                                         |
| <b>Peripheral DMA (PDMA)</b>               | <ul style="list-style-type: none"><li>Sixteen independent and configurable channels for automatic data transfer between memories and peripherals</li><li>Basic and Scatter-Gather transfer modes</li><li>Each channel supports circular buffer management using Scatter-Gather Transfer mode</li><li>Stride function for rectangle image data movement</li><li>Fixed-priority and Round-robin priorities modes</li><li>Single and burst transfer types</li><li>Byte-, half-word- and word transfer unit with count up to 65536</li><li>Incremental or fixed source and destination address</li></ul> |
| <b>Clocks</b>                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>External Clock Source</b>               | <ul style="list-style-type: none"><li>4~24 MHz High-speed eXternal crystal oscillator (HXT) for precise timing operation</li><li>32.768 kHz Low-speed eXternal crystal oscillator (LXT) for RTC function and low-power system operation</li><li>Supports clock failure detection for external crystal oscillators and</li></ul>                                                                                                                                                                                                                                                                      |

---

exception generation (NMI)

---

**Internal Clock Source**

- 12 MHz High-speed Internal RC oscillator (HIRC) trimmed to 2% accuracy that can optionally be used as a system clock
  - 10 kHz Low-speed Internal RC oscillator (LIRC) for watchdog timer and wakeup operation
  - Up to 480 MHz on-chip PLL, sourced from HIRC or HXT, allows CPU operation up to the maximum CPU frequency without the need for a high-frequency crystal
- 

**Real-Time Clock (RTC)**

- Real-Time Clock with a separate power domain
  - The RTC clock source includes Low-speed external crystal oscillator (LXT)
  - The RTC block includes 80 bytes backup registers, which can be cleared by tamper pins
  - Supports 6 static and dynamic tamper pins
  - Able to wake up CPU from any reduced power mode
  - Supports ±5ppm within 5 seconds software clock accuracy compensation
  - Supports Alarm registers (second, minute, hour, day, month, year)
  - Supports RTC Time Tick and Alarm Match interrupt
  - Automatic leap year recognition
  - Supports 1 Hz clock output for calibration
- 

***Timers*****TIMER**

- Four sets of 32-bit timers with 24-bit up counter and one 8-bit pre-scale counter from independent clock source
- One-shot, Periodic, Toggle and Continuous Counting operation modes
- Supports event counting function to count the event from external pins
- Supports external capture pin for interval measurement and resetting 24-bit up counter
- Supports chip wake-up function, if a timer interrupt signal is generated

**PWM**

- Eight 16-bit PWM counters with 12-bit clock prescale with up to 192 MHz
- Supports 12-bit deadband (dead time)
- Up, down or up-down PWM counter type
- Supports brake function
- Supports mask function and tri-state output for each PWM channel

**Enhanced PWM (EPWM)**

- Twelve 16-bit counters with 12-bit clock prescale for twelve 192
-

---

MHz PWM output channels

- Up to 12 independent input capture channels with 16-bit resolution counter
  - Supports dead time with maximum divided 12-bit prescale
  - Up, down or up-down PWM counter type
  - Supports complementary mode for 3 complementary paired PWM output channels
  - Synchronous function for phase control
  - Counter synchronous start function
  - Brake function with auto recovery mechanism
  - Mask function and tri-state output for each PWM channel
  - Able to trigger EADC or DAC to start conversion
- 

- Two 16-bit counters with 12-bit clock prescale for twelve 192 MHz PWM output channels.

**Basic PWM (BPWM)**

- Up to 6 independent input capture channels with 16-bit resolution counter
  - Up, down or up-down PWM counter type
  - Counter synchronous start function
  - Complementary mode for 3 complementary paired PWM output channels
  - Mask function and tri-state output for each PWM channel
  - Able to trigger EADC to start conversion.
- 

**Watchdog**

- 18-bit free running up counter for WDT time-out interval
  - Supports multiple clock sources from LIRC (default selection), HCLK/2048 and LXT with 8 selectable time-out period
  - Able to wake up system from Power-down or Idle mode
  - Time-out event to trigger interrupt or reset system
  - Supports four WDT reset delay periods, including 1026, 130, 18 or 3 WDT\_CLK reset delay period
  - Configured to force WDT enabled on chip power-on or reset.
- 

**Window Watchdog**

- Clock sourced from HCLK/2048 or LIRC; the window set by 6-bit counter with 11-bit prescale
  - Suspended in Idle/Power-down mode
- 

**Analog Interfaces**

**Enhanced Analog-to-Digital Converter (EADC)**

- One 12-bit, 19-ch 5 MSPS SAR EADC with up to 16 single-ended input channels or 8 differential input pairs; 10-bit accuracy is guaranteed.
  - Three internal channels for V<sub>DD</sub>, band-gap VBG input and Temperature sensor input
  - Supports external V<sub>REF</sub> pin or internal reference voltage V<sub>REF</sub>: 1.6V, 2.0V, 2.5V, and 3.0V.
-

|                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                   | <ul style="list-style-type: none"><li>• Two power saving modes: Power-down mode and Standby mode</li><li>• Supports calibration capability.</li><li>• Analog-to-Digital conversion can be triggered by software enable, external pin, Timer 0~3 overflow pulse trigger or PWM trigger.</li><li>• Configurable EADC sampling time.</li><li>• Up to 19 sample modules.</li><li>• Double data buffers for sample module 0~3.</li><li>• PDMA operation.</li></ul>                                                                                                                                                                                        |
| Digital-to-Analog Converter (DAC) | <ul style="list-style-type: none"><li>• Two 12-bit, 1 MSPS voltage type DAC with 8-bit mode and 8μs rail-to-rail settle time.</li><li>• Maximum output voltage AV<sub>DD</sub> -0.2V at buffer mode</li><li>• Digital-to-Analog conversion triggered by Timer0~3, EPWM0, EPWM1, external trigger pin to start DAC conversion or software.</li><li>• Supports group mode for synchronized data update of two DACs.</li><li>• PDMA operation</li></ul>                                                                                                                                                                                                 |
| Analog Comparator (ACMP)          | <ul style="list-style-type: none"><li>• Two rail-to-rail Analog Comparators.</li><li>• Supports four multiplexed I/O pins at positive input.</li><li>• Supports I/O pins, band-gap, DAC, and 16-level Voltage divider from AV<sub>DD</sub> or V<sub>REF</sub> at negative input</li><li>• Supports four programmable propagation speeds for power saving</li><li>• Supports wake up from Power-down by interrupt</li><li>• Supports triggers for brake events and cycle-by-cycle control for PWM</li><li>• Supports window compare mode and window latch mode.</li><li>• Supports programmable hysteresis window: 0mV, 10mV, 20mV and 30mV</li></ul> |
| Operational Amplifier (OPA)       | <ul style="list-style-type: none"><li>• Three Operational Amplifiers with 0~AV<sub>DD</sub> input voltage range.</li><li>• OPA schmitt trigger buffer output used as the interrupt source of comparator.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Communication Interfaces</b>   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Low-power UART                    | <ul style="list-style-type: none"><li>• Six sets of UARTs with up to 17.45 MHz baud rate.</li><li>• Auto-Baud Rate measurement and baud rate compensation function.</li><li>• Supports low power UART (LPUART): baud rate clock from LXT(32.768 KHz) with 9600bps in Power-down mode even system clock is stopped.</li><li>• 16-byte FIFOs with programmable level trigger</li><li>• Auto flow control ( nCTS and nRTS)</li><li>• Supports IrDA (SIR) function</li><li>• Supports LIN function on UART0 and UART1</li></ul>                                                                                                                          |

- Supports RS-485 9-bit mode and direction control
- Supports nCTS, incoming data, Received Data FIFO reached threshold and RS-485 Address Match (AAD mode) wake-up function in idle mode.
- Supports hardware or software enables to program nRTS pin to control RS-485 transmission direction
- Supports wake-up function
- 8-bit receiver FIFO time-out detection function
- Supports break error, frame error, parity error and receive/transmit FIFO overflow detection function
- PDMA operation.

**Smart Card Interface**

- Three sets of ISO-7816-3 which are compliant with ISO-7816-3 T=0, T=1
- Supports full duplex UART function.
- 4-byte FIFOs with programmable level trigger
- Programmable guard time selection (11 ETU ~ 266 ETU)
- One 24-bit and two 8 bit time-out counters for Answer to Request (ATR) and waiting times processing
- Auto inverse convention function
- Stop clock level and clock stop (clock keep) function
- Transmitter and receiver error retry function
- Supports hardware activation, deactivation and warm reset sequence process
- Supports hardware auto deactivation sequence after card removal.

**I<sup>2</sup>C**

- Three sets of I<sup>2</sup>C devices with Master/Slave mode.
- Supports Standard mode (100 kbps), Fast mode (400 kbps) and Fast mode plus (1 Mbps)
- Supports 10 bits mode
- Programmable clocks allowing for versatile rate control
- Supports multiple address recognition (four slave address with mask option)
- Supports SMBus and PMBus
- Supports multi-address power-down wake-up function
- PDMA operation

**SPI Master (SPI Flash)**

- Maximum 32 MB external SPI Flash memory with standard (1-bit), dual (2-bit) and quad (4-bit) transfer mode with Up to 96 Mbit/s.
- 32 KB cache memory for enhancing program execution performance.
- 64-bit key length for code protection.
- DMA mode for code transfer between SPI Flash memory and SRAM.
- SPI Master function with 8-, 16-, 24-, and 32-bit length of transaction and burst mode operation, which can transmit/receive

---

data up to four successive transactions in one transfer.

---

- One set of SPI Quad controller with Master/Slave mode, up to 96 MHz at 2.7V~3.6V system voltage.
  - Supports Dual and Quad I/O Transfer mode
  - Supports one/two data channel half-duplex transfer
  - Supports receive-only mode
  - Configurable bit length of a transfer 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 the byte reorder function
  - Supports Byte or Word Suspend mode
  - Supports 3-wired, no slave select signal, bi-direction interface
  - PDMA operation.
- 

- Up to four sets of SPI/I2S controllers with Master/Slave mode.
- SPI/I2S provides separate 4-level of 32-bit (or 8-level of 16-bit) transmit and receive FIFO buffers.

#### SPI

- SPI can communicate at up to 96 Mbit/s
- Configurable bit length of a transfer word from 8 to 32-bit.
- MSB first or LSB first transfer sequence.
- Byte reorder function.
- Supports Byte or Word Suspend mode.
- Supports one data channel half-duplex transfer.
- Supports receive-only mode.

#### I<sup>2</sup>S

- Supports mono and stereo audio data with 8-, 16-, 24- and 32-bit audio data sizes.
  - Supports PCM mode A, PCM mode B, I2S and MSB justified data format.
  - PDMA operation.
- 

- One set of I2S interface with Master/Slave mode.
  - I2S audio sampling frequencies up to 192 kHz are supported.
  - Supports mono and stereo audio data with 8-, 16-, 24- and 32-bit word sizes.
  - Two 16-level FIFO data buffers, one for transmitting and the other for receiving.
  - Supports I2S protocols: Philips standard, MSB-justified, and LSB-justified data format.
  - Supports PCM protocols: PCM standard, MSB-justified, and LSB-justified data format.
  - PCM protocol supports TDM multi-channel transmission in one
-

audio sample; the number of data channel can be set as 2, 4, 6 or 8.

- PDMA operation.
- Two sets of USCI, configured as UART, SPI or I2C function.
- Supports single byte TX and RX buffer mode

### **UART**

- Supports one transmit buffer and two receive buffers for data payload.
- Supports hardware auto flow control function and programmable flow control trigger level.
- 9-bit Data Transfer.
- Baud rate detection by built-in capture event of baud rate generator.
- Supports wake-up function.
- PDMA operation.

### **SPI**

- Supports Master or Slave mode operation.
- Supports one transmit buffer and two receive buffer for data payload.
- Supports additional receive/transmit 16 entries FIFO for data payload.
- Configurable bit length of a transfer word from 4 to 16-bit (SPI Quad transmission only supports 8 to 16-bit of word length).
- Supports MSB first or LSB first transfer sequence.
- Supports Word Suspend function.
- Supports 3-wire, no slave select signal, bi-direction interface.
- Supports wake-up function: input slave select transition.
- PDMA operation.

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

- Supports master and slave device capability.
- Supports one transmit buffer and two receive buffer for data payload.
- Communication in standard mode (100 kbps), fast mode (up to 400 kbps), and Fast mode plus (1 Mbps).
- Supports 10-bit mode.
- Supports 10-bit bus time out capability.
- Supports bus monitor mode.
- Supports power-down wake-up by data toggle or address match.
- Supports multiple address recognition.
- Supports device address flag.
- Programmable setup/hold time.

---

### **Universal Serial Control Interface (USCI)**

- 
- Two sets of CAN 2.0B controllers.
  - Each supports 32 Message Objects; each Message Object has its

**Secure Digital Host Controller (SDHC)**

- own identifier mask.
- Programmable FIFO mode (concatenation of Message Object).
- Disabled Automatic Re-transmission mode for Time Triggered CAN applications.
- Supports power-down wake-up function.

**External Bus Interface (EBI)**

- Two sets of Secure Digital Host Controllers, compliant with SD Memory Card Specification Version 2.0.
- Supports 50 MHz to achieve 200 Mbps at 3.3V operation.
- Supports dedicated DMA master with Scatter-Gather function to accelerate the data transfer between system memory and SD/SDHC/SDIO card.
- Supports up to three memory banks with individual adjustment of timing parameter.
- Each bank supports dedicated external chip select pin with polarity control and up to 1 MB addressing space.
- 8-/16-bit data width.
- Supports byte write in 16-bit data width mode.
- Configurable idle cycle for different access condition: Idle of Write command finish (W2X) and Idle of Read-to-Read (R2R).
- Supports Address/Data multiplexed mode.
- Supports address bus and data bus separate mode.
- Supports LCD interface i80 mode.
- PDMA operation.

**GPIO**

- Supports four I/O modes: Quasi bi-direction, Push-Pull output, Open-Drain output and Input only with high impedance mode.
- Selectable TTL/Schmitt trigger input.
- Configured as interrupt source with edge/level trigger setting.
- Supports independent pull-up/pull-down control.
- Supports high driver and high sink current I/O.
- Supports software selectable slew rate control.
- Supports 5V-tolerance function except analog I/O. (Except PA.8 ~ 15; PB.0 ~ 15; PD.10 ~ 12; PF.2 ~ 5; All USB High Speed PIN; nReset.)

**Control Interfaces****Quadrature Encoder Interface (QEI)**

- Two QEI phase inputs (QEI\_A, QEI\_B) and one Index input (QEI\_INDEX).
- Supports 2/4 times free-counting mode and 2/4 compare-counting mode.
- Supports encoder pulse width measurement mode with ECAP.

**Enhanced Capture (ECAP)    Input Capture Timer/Counter**

- 
- Supports three input channels with independent capture counter hold register.
  - 24-bit Input Capture up-counting timer/counter supports captured events reset and/or reload capture counter.
  - Supports rising edge, falling edge and both edge detector options with noise filter in front of input ports.
  - Supports compare-match function.
- 

## Advanced Connectivity

---

### USB 2.0 Full Speed OTG (On-The-Go)

- On-chip USB 2.0 full speed OTG transceiver.
- Compliant with USB OTG Supplement 2.0
- Configurable as host-only, device-only or ID-dependent

### USB 2.0 Full Speed Host Controller

- Compliant with USB Revision 1.1 Specification.
- Compatible with OHCI (Open Host Controller Interface) Revision 1.0.
- Supports full-speed (12Mbps) and low-speed (1.5Mbps) USB devices.
- Supports Control, Bulk, Interrupt, Isochronous and Split transfers.
- Integrated a port routing logic to route full/low speed device to OHCI controller.
- Supports an integrated Root Hub.
- Supports port power control and port over current detection.
- Built-in DMA.

### USB 2.0 Full Speed Device Controller

- Compliant with USB Revision 2.0 Specification.
  - Supports suspend function when no bus activity existing for 3 ms.
  - 12 configurable endpoints for configurable Isochronous, Bulk, Interrupt and Control transfer types.
  - 1024 bytes configurable RAM for endpoint buffer.
  - Remote wake-up capability.
- 

### USB 2.0 High Speed OTG (On-The-Go)

- On-chip USB 2.0 high speed OTG transceiver.
- Compliant with USB OTG Supplement 2.0.
- Configurable as host-only, device-only or ID-dependent.

### USB 2.0 High Speed Host Controller

- Compliant with USB Revision 2.0 Specification.
- Compatible with EHCI (Enhanced Host Controller Interface) Revision 1.0.
- Compatible with OHCI (Open Host Controller Interface) Revision 1.0.

### USB 2.0 High Speed with on-chip transceiver

- Supports high-speed (480Mbps), full-speed (12Mbps) and low-speed (1.5Mbps) USB devices.
- Integrated a port routing logic to route full/low speed device to OHCI controller.
- Supports an integrated Root Hub.
- Built-in DMA.

#### USB 2.0 High Speed Device Controller

- Compliant with USB Revision 2.0 Specification.
- Supports one dedicate control endpoint and 12 configurable endpoints; each can be Isochronous, Bulk or Interrupt and either IN or OUT direction.
- 4096 bytes configurable RAM for endpoint buffer and up to 1024 bytes maximum packet size.
- Three different operation modes of an in-endpoint: Auto Validation mode, Manual Validation mode and Fly mode.
- Suspend, resume and remote wake-up capability.
- Built-in DMA.

- 
- IEEE Std. 802.3 CSMA/CD protocol.
  - Ethernet frame time stamping for IEEE Std. 1588 – 2002 protocol.
  - Supports both half and full duplex for 10 Mbps or 100 Mbps operation.
  - RMII (Reduced Media Independent Interface) and serial management interface (MDC/MDIO).

#### Ethernet MAC

- Pause and remote pause function for flow control.
- Long frame (more than 1518 bytes) and short frame (less than 64 bytes) reception.
- CAM function for Ethernet MAC address recognition.
- Supports Magic Packet recognition to wake system up from Power-down mode.
- Built-in DMA.

---

#### Cryptography Accelerator

#### Elliptic Curve Cryptography (ECC)

- Hardware ECC accelerator.
- Supports 192-bit and 256-bit key length.
- Supports both prime field GF(p) and binary field GF(2<sup>m</sup>).
- Supports NIST P-192, P-224, P-256, P-384 and P-521 curve sizes.
- Supports NIST B-163, B-233, B-283, B-409 and B-571 curve sizes.
- Supports NIST K-163, K-233, K-283, K-409 and K-571 curve sizes.
- Supports point multiplication, addition and doubling operations in GF(p) and GF(2<sup>m</sup>).
- Supports modulus division, multiplication, addition and subtraction operations in GF(p).

**Advanced Encryption Standard (AES)**

- Hardware AES accelerator.
- Supports 128-bit, 192-bit and 256-bit key length and key expander, and is compliant with FIPS 197.
- Supports ECB, CBC, CFB, OFB, CTR, CBC-CS1, CBC-CS2 and CBC-CS3 block cipher modes
- Compliant with NIST SP800-38A and addendum.

**Data Encryption Standard (DES)**

- Hardware DES accelerator.
- Supports ECB, CBC, CFB, OFB, and CTR block cipher mode.
- Compliant with FIPS 46-3.

**Triple Data Encryption Standard (3DES)**

- Hardware Triple DES accelerator.
- Supports two or three different keys in each round.
- Supports ECB, CBC, CFB, OFB, and CTR block cipher mode.
- Implemented based on X9.52 standard and compliant with FIPS SP 800-67.

**Secure Hash Algorithm (SHA)**

- Hardware SHA accelerator.
- Supports SHA-160, SHA-224, SHA-256, SHA-384 and SHA-512.
- Compliant with FIPS 180/180-2.

**keyed-Hash Message Authentication Code (HMAC)**

- Hardware HMAC accelerator.
- Supports HMAC-SHA-160, HMAC-SHA-224, HMAC-SHA-256, HMAC-SHA-384, and HMAC-SHA-512.
- Compliant with FIPS 180/180-2.

### 3 PARTS INFORMATION

#### 3.1 Summary

| Part No. | USB FS | USB HS | CAN | Crypto | Ethernet |
|----------|--------|--------|-----|--------|----------|
| M481     | –      | –      | –   | –      | –        |
| M482     | √      | –      | –   | –      | –        |
| M483     | √      | √      | √   | –      | –        |
| M484     | √      | √      | –   | –      | –        |
| M485     | √      | √      | –   | √      | –        |
| M487     | √      | √      | √   | √      | √        |

#### 3.2 Package Type

| Part No. | QFN33                  | LQFP48                 | LQFP64                                               | LQFP128                | LQFP144   |
|----------|------------------------|------------------------|------------------------------------------------------|------------------------|-----------|
| M481     | M481ZGAAE<br>M481ZIDAE | M481LGAAE<br>M481LIDAE | M481SGAAE<br>M481SIDAE                               |                        |           |
| M482     | M482ZIDAE              | M482LGAAE<br>M482LIDAE | M482SGAAE<br>M482SIDAE                               | M482KGAAE<br>M482KIDAE |           |
| M483     |                        |                        | M483SGAAE<br>M483SIDAE                               | M483KIDAE              |           |
| M484     |                        |                        | M484SGAAE<br>M484SIDAE<br>M484SGAAE2U<br>M484SIDAE2U | M484KIDAE              |           |
| M485     | M485ZIDAE              | M485LIDAE              | M485SIDAE                                            | M485KIDAE              |           |
| M487     |                        |                        | M487SIDAE                                            | M487KIDAE              | M487JIDAE |

## 3.3 NuMicro® M481 Base Series

| PART NUMBER                                       |                      | M481  |         |       |         |       |       |
|---------------------------------------------------|----------------------|-------|---------|-------|---------|-------|-------|
|                                                   |                      | ZGAAE | ZIDAE   | LGAAE | LIDAE   | SGAAE | SIDAE |
| Flash (KB)                                        |                      | 256   | 512     | 256   | 512     | 256   | 512   |
| SRAM (KB)                                         |                      | 96    | 160     | 96    | 160     | 96    | 160   |
| ISP Loader ROM (KB)                               |                      |       |         | 4     |         |       |       |
| I/O                                               |                      | 26    |         | 41    |         | 52    |       |
| 32-bit Timer                                      |                      |       |         | 4     |         |       |       |
| Tamper                                            |                      | -     |         | -     |         | 1     |       |
| Connectivity                                      | LPUART               |       |         | 6     |         |       |       |
|                                                   | ISO-7816             |       |         | 3     |         |       |       |
|                                                   | SPI Master           |       |         | 1     |         |       |       |
|                                                   | Quad SPI             |       |         | 1     |         |       |       |
|                                                   | SPI/I <sup>2</sup> S | 3     |         | 3     |         | 4     |       |
|                                                   | I <sup>2</sup> S     |       |         | 1     |         |       |       |
|                                                   | I <sup>2</sup> C     |       |         | 3     |         |       |       |
|                                                   | USCI                 |       |         | 2     |         |       |       |
|                                                   | CAN                  |       |         | -     |         |       |       |
|                                                   | LIN                  |       |         | 2     |         |       |       |
|                                                   | SDHC                 | 1     |         | 2     |         | 2     |       |
|                                                   | 16-bit PWM           |       |         | 24    |         |       |       |
|                                                   | QEI                  | 1     |         | 2     |         | 2     |       |
|                                                   | ECAP                 | -     |         | 1     |         | 1     |       |
| USB 2.0 FS OTG                                    |                      |       |         | -     |         |       |       |
| USB 2.0 HS OTG                                    |                      |       |         | -     |         |       |       |
| 12-bit ADC                                        | 10                   |       | 12      |       | 16      |       |       |
| 12-bit DAC                                        |                      |       | 2       |       |         |       |       |
| Analog Comparator                                 |                      |       | 2       |       |         |       |       |
| Operational Amplifier                             | 1                    |       | 2       |       | 2       |       |       |
| Ethernet                                          |                      |       | -       |       |         |       |       |
| Cryptography                                      |                      |       | -       |       |         |       |       |
| LCD Parallel Data Bus<br>(External Bus Interface) | -                    |       | 8       |       | 16      |       |       |
| Package                                           | QFN 33               |       | LQFP 48 |       | LQFP 64 |       |       |

## 3.4 NuMicro® M482 USB FS OTG Series

| PART NUMBER                                       | M482                 |       |         |       |         |       |          |
|---------------------------------------------------|----------------------|-------|---------|-------|---------|-------|----------|
|                                                   | ZIDAE                | LGAAE | LIDAE   | SGAAE | SIDAE   | KGAAE | KIDAE    |
| Flash (KB)                                        | 512                  | 256   | 512     | 256   | 512     | 256   | 512      |
| SRAM (KB)                                         | 160                  | 96    | 160     | 96    | 160     | 96    | 160      |
| ISP Loader ROM (KB)                               |                      |       |         | 4     |         |       |          |
| I/O                                               | 26                   |       | 41      |       | 52      |       | 100      |
| 32-bit Timer                                      |                      |       |         | 4     |         |       |          |
| Tamper                                            | -                    |       | -       |       | 1       |       | 6        |
| Connectivity                                      | LPUART               |       |         | 6     |         |       |          |
|                                                   | ISO-7816             |       |         | 3     |         |       |          |
|                                                   | SPI Master           |       |         | 1     |         |       |          |
|                                                   | Quad SPI             |       |         | 1     |         |       |          |
|                                                   | SPI/I <sup>2</sup> S | 3     |         | 3     |         | 4     | 4        |
|                                                   | I <sup>2</sup> S     |       |         | 1     |         |       |          |
|                                                   | I <sup>2</sup> C     |       |         | 3     |         |       |          |
|                                                   | USCI                 |       |         | 2     |         |       |          |
|                                                   | CAN                  |       |         | -     |         |       |          |
|                                                   | LIN                  |       |         | 2     |         |       |          |
|                                                   | SDHC                 |       |         | 2     |         |       |          |
| 16-bit PWM                                        |                      |       |         | 24    |         |       |          |
| QEI                                               | 1                    |       | 2       |       | 2       |       | 2        |
| ECAP                                              | -                    |       | 1       |       | 1       |       | 2        |
| USB 2.0 FS OTG                                    |                      |       |         | ✓     |         |       |          |
| USB 2.0 HS OTG                                    |                      |       |         | -     |         |       |          |
| 12-bit ADC                                        | 10                   |       | 12      |       | 16      |       | 16       |
| 12-bit DAC                                        |                      |       | 2       |       |         |       |          |
| Analog Comparator                                 |                      |       | 2       |       |         |       |          |
| Operational Amplifier                             | 1                    |       | 2       |       | 2       |       | 3        |
| Ethernet                                          |                      |       | -       |       |         |       |          |
| Cryptography                                      |                      |       | -       |       |         |       |          |
| LCD Parallel Data Bus<br>(External Bus Interface) | -                    |       | 8       |       | 16      |       | 16       |
| Package                                           | QFN33                |       | LQFP 48 |       | LQFP 64 |       | LQFP 128 |

## 3.5 NuMicro® M483 CAN Series

| PART NUMBER                                       | M483                 |          |       |
|---------------------------------------------------|----------------------|----------|-------|
|                                                   | SGAAE                | SIDAE    | KIDAE |
| Flash (KB)                                        | 256                  | 512      | 512   |
| SRAM (KB)                                         | 96                   | 160      | 160   |
| ISP Loader ROM (KB)                               |                      |          | 4     |
| I/O                                               | 44                   |          | 100   |
| 32-bit Timer                                      |                      |          | 4     |
| Tamper                                            | 1                    |          | 6     |
| Connectivity                                      | LPUART               | 6        |       |
|                                                   | ISO-7816             | 3        |       |
|                                                   | SPI Master           | 1        |       |
|                                                   | Quad SPI             | 1        |       |
|                                                   | SPI/I <sup>2</sup> S | 4        |       |
|                                                   | I <sup>2</sup> S     | 1        |       |
|                                                   | I <sup>2</sup> C     | 3        |       |
|                                                   | USCI                 | 2        |       |
|                                                   | CAN                  | 2        |       |
|                                                   | LIN                  | 2        |       |
|                                                   | SDHC                 | 2        |       |
| 16-bit PWM                                        | 24                   |          |       |
| QEI                                               | 2                    |          |       |
| ECAP                                              | 1                    | 2        |       |
| USB 2.0 FS OTG                                    | -                    | √        |       |
| USB 2.0 HS OTG                                    |                      | √        |       |
| 12-bit ADC                                        | 16                   |          |       |
| 12-bit DAC                                        | 2                    |          |       |
| Analog Comparator                                 | 2                    |          |       |
| Operational Amplifier                             | 2                    | 3        |       |
| Ethernet                                          | -                    |          |       |
| Cryptography                                      | -                    |          |       |
| LCD Parallel Data Bus<br>(External Bus Interface) | 8                    | 16       |       |
| Package                                           | LQFP 64              | LQFP 128 |       |

## 3.6 NuMicro® M484 USB HS OTG Series

| PART NUMBER                                       | M484                 |       |         |         |          |
|---------------------------------------------------|----------------------|-------|---------|---------|----------|
|                                                   | SGAAE                | SIDAE | SGAAE2U | SIDAE2U | KIDAE    |
| Flash (KB)                                        | 256                  | 512   | 256     | 512     | 512      |
| SRAM (KB)                                         | 96                   | 160   | 96      | 160     | 160      |
| ISP Loader ROM (KB)                               |                      |       | 4       |         |          |
| I/O                                               | 44                   |       | 44      |         | 100      |
| 32-bit Timer                                      |                      |       | 4       |         |          |
| Tamper                                            | 1                    |       | 1       |         | 6        |
| Connectivity                                      | LPUART               |       | 6       |         |          |
|                                                   | ISO-7816             |       | 3       |         |          |
|                                                   | SPI Master           |       | 1       |         |          |
|                                                   | Quad SPI             |       | 1       |         |          |
|                                                   | SPI/I <sup>2</sup> S |       | 4       |         |          |
|                                                   | I <sup>2</sup> S     |       | 1       |         |          |
|                                                   | I <sup>2</sup> C     |       | 3       |         |          |
|                                                   | USCI                 |       | 2       |         |          |
|                                                   | CAN                  |       | -       |         |          |
|                                                   | LIN                  |       | 2       |         |          |
|                                                   | SDHC                 |       | 2       |         |          |
| 16-bit PWM                                        |                      |       | 24      |         |          |
| QEI                                               |                      |       | 2       |         |          |
| ECAP                                              | 1                    |       | 1       |         | 2        |
| USB 2.0 FS OTG                                    | -                    |       | ✓       |         | ✓        |
| USB 2.0 HS OTG                                    |                      |       | ✓       |         |          |
| 12-bit ADC                                        |                      |       | 16      |         |          |
| 12-bit DAC                                        |                      |       | 2       |         |          |
| Analog Comparator                                 |                      |       | 2       |         |          |
| Operational Amplifier                             | 2                    |       | 2       |         | 3        |
| Ethernet                                          |                      |       | -       |         |          |
| Cryptography                                      |                      |       | -       |         |          |
| LCD Parallel Data Bus<br>(External Bus Interface) | 8                    |       | 8       |         | 16       |
| Package                                           | LQFP 64              |       | LQFP 64 |         | LQFP 128 |

### 3.7 NuMicro® M485 Crypto Series

| PART NUMBER                                       | M485                 |         |         |          |
|---------------------------------------------------|----------------------|---------|---------|----------|
|                                                   | ZIDAE                | LIDAE   | SIDAE   | KIDAE    |
| Flash (KB)                                        |                      |         | 512     |          |
| SRAM (KB)                                         |                      |         | 160     |          |
| ISP Loader ROM (KB)                               |                      |         | 4       |          |
| I/O                                               | 26                   | 41      | 44      | 100      |
| 32-bit Timer                                      |                      |         | 4       |          |
| Tamper                                            | -                    | -       | 1       | 6        |
| Connectivity                                      | LPUART               |         |         | 6        |
|                                                   | ISO-7816             |         |         | 3        |
|                                                   | SPI Master           |         |         | 1        |
|                                                   | Quad SPI             |         |         | 1        |
|                                                   | SPI/I <sup>2</sup> S | 3       | 3       | 4        |
|                                                   | I <sup>2</sup> S     |         |         | 1        |
|                                                   | I <sup>2</sup> C     |         |         | 3        |
|                                                   | USCI                 |         |         | 2        |
|                                                   | CAN                  |         |         | -        |
|                                                   | LIN                  |         |         | 2        |
|                                                   | SDHC                 | 1       | 2       | 2        |
| 16-bit PWM                                        |                      | 24      |         |          |
| QEI                                               | 1                    | 2       | 2       | 2        |
| ECAP                                              | -                    | 1       | 1       | 2        |
| USB 2.0 FS OTG                                    | √                    | √       | -       | √        |
| USB 2.0 HS OTG                                    | -                    | -       | √       | √        |
| 12-bit ADC                                        | 10                   | 12      | 16      | 16       |
| 12-bit DAC                                        |                      |         | 2       |          |
| Analog Comparator                                 |                      |         | 2       |          |
| Operational Amplifier                             | 1                    | 2       | 2       | 3        |
| Ethernet                                          |                      |         | -       |          |
| Cryptography                                      |                      |         | √       |          |
| LCD Parallel Data Bus<br>(External Bus Interface) | -                    | 8       | 8       | 16       |
| Package                                           | QFN33                | LQFP 48 | LQFP 64 | LQFP 128 |

## 3.8 NuMicro® M487 Ethernet Series

| PART NUMBER                                    |                      | M487    |          |          |
|------------------------------------------------|----------------------|---------|----------|----------|
|                                                |                      | SIDAE   | KIDAE    | JIDAE    |
| Flash (KB)                                     |                      | 512     |          |          |
| SRAM (KB)                                      |                      | 160     |          |          |
| ISP Loader ROM (KB)                            |                      | 4       |          |          |
| I/O                                            |                      | 44      | 100      | 114      |
| 32-bit Timer                                   |                      | 4       |          |          |
| Tamper                                         |                      | 1       | 6        | 6        |
| Connectivity                                   | LPUART               | 6       |          |          |
|                                                | ISO-7816             | 3       |          |          |
|                                                | SPI Master           | 1       |          |          |
|                                                | Quad SPI             | 1       |          |          |
|                                                | SPI/I <sup>2</sup> S | 4       |          |          |
|                                                | I <sup>2</sup> S     | 1       |          |          |
|                                                | I <sup>2</sup> C     | 3       |          |          |
|                                                | USCI                 | 2       |          |          |
|                                                | CAN                  | 2       |          |          |
|                                                | LIN                  | 2       |          |          |
|                                                | SDHC                 | 2       |          |          |
| 16-bit PWM                                     |                      | 24      |          |          |
| QEI                                            |                      | 2       |          |          |
| ECAP                                           |                      | 1       | 2        | 2        |
| USB 2.0 FS OTG                                 |                      | -       | √        | √        |
| USB 2.0 HS OTG                                 |                      | √       |          |          |
| 12-bit ADC                                     |                      | 16      |          |          |
| 12-bit DAC                                     |                      | 2       |          |          |
| Analog Comparator                              |                      | 2       |          |          |
| Operational Amplifier                          |                      | 2       | 3        | 3        |
| Ethernet                                       |                      | √       |          |          |
| Cryptography                                   |                      | √       |          |          |
| LCD Parallel Data Bus (External Bus Interface) |                      | 8       | 16       | 16       |
| Package                                        |                      | LQFP 64 | LQFP 128 | LQFP 144 |

### 3.9 NuMicro® M480 Naming Rule



## 4 PIN CONFIGURATION

### 4.1 Pin Configuration

#### 4.1.1 NuMicro® M481 Base Series QFN33 Pin Diagram

Corresponding Part Number: M481ZGAAE, M481ZIDAE



Figure 4.1-1 NuMicro® M481 Base Series QFN 33-pin Diagram

#### 4.1.2 NuMicro® M481 Base Series LQFP48 Pin Diagram

Corresponding Part Number: M481LGAAE, M481LIDAE



Figure 4.1-2 NuMicro® M481 Base Series LQFP 48-pin Diagram

#### 4.1.3 NuMicro® M481 Base Series LQFP64 Pin Diagram

Corresponding Part Number: M481SGAAE, M481SIDAE



Figure 4.1-3 NuMicro® M481 Base Series LQFP 64-pin Diagram

## 4.1.4 NuMicro® M482 USB FS OTG Series QFN33 Pin Diagram

Corresponding Part Number: M482ZIDAE



Figure 4.1-4 NuMicro® M482 USB FS OTG Series QFN 33-pin Diagram

#### 4.1.5 NuMicro® M482 USB FS OTG Series LQFP48 Pin Diagram

Corresponding Part Number: M482LGAAE, M482LIDAE



Figure 4.1-5 NuMicro® M482 USB FS OTG Series LQFP 48-pin Diagram

#### 4.1.6 NuMicro® M482 USB FS OTG Series LQFP64 Pin Diagram

Corresponding Part Number: M482SGAAE, M482SIDAE



Figure 4.1-6 NuMicro® M482 USB FS OTG Series LQFP 64-pin Diagram

#### 4.1.7 NuMicro® M482 USB FS OTG Series LQFP128 Pin Diagram

Corresponding Part Number: M482KGAAE, M482KIDAE



Figure 4.1-7 NuMicro® M482 USB FS OTG Series LQFP 128-pin Diagram

#### 4.1.8 NuMicro® M483 CAN Series LQFP64 Pin Diagram

Corresponding Part Number: M483SGAAE, M483SIDAE



Figure 4.1-8 NuMicro® M483 CAN Series LQFP 64-pin Diagram

#### 4.1.9 NuMicro® M483 CAN Series LQFP128 Pin Diagram

Corresponding Part Number: M483KIDAE



Figure 4.1-9 NuMicro® M483 CAN Series LQFP 128-pin Diagram

#### 4.1.10 NuMicro® M484 USB HS OTG Series LQFP64 Pin Diagram

Corresponding Part Number: M484SGAAE, M484SIDAE



Figure 4.1-10 NuMicro® M484 USB HS OTG Series LQFP 64-pin Diagram

#### 4.1.11 NuMicro® M484 USB HS OTG Series with 2 USB LQFP64 Pin Diagram

Corresponding Part Number: M484SGAAE2U, M484SIDAE2U



Figure 4.1-11 NuMicro® M484 USB HS OTG Series with 2 USB LQFP 64-pin Diagram

#### 4.1.12 NuMicro® M484 USB HS OTG Series LQFP128 Pin Diagram

Corresponding Part Number: M484KIDAE



Figure 4.1-12 NuMicro® M484 USB HS OTG Series LQFP 128-pin Diagram

#### 4.1.13 NuMicro® M485 Crypto Series QFN33 Pin Diagram

Corresponding Part Number: M485ZIDAE



Figure 4.1-13 NuMicro® M485 Crypto Series QFN 33-pin Diagram

## 4.1.14 NuMicro® M485 Crypto Series LQFP48 Pin Diagram

Corresponding Part Number: M485LIDAE



Figure 4.1-14 NuMicro® M485 Crypto Series LQFP 48-pin Diagram

#### 4.1.15 NuMicro® M485 Crypto Series LQFP64 Pin Diagram

Corresponding Part Number: M485SIDAE



Figure 4.1-15 NuMicro® M485 Crypto Series LQFP 64-pin Diagram

#### 4.1.16 NuMicro® M485 Crypto Series LQFP128 Pin Diagram

Corresponding Part Number: M485KIDAE



Figure 4.1-16 NuMicro® M485 Crypto Series LQFP 128-pin Diagram

#### 4.1.17 NuMicro® M487 Ethernet Series LQFP64 Pin Diagram

Corresponding Part Number: M487SIDAE



Figure 4.1-17 NuMicro® M487 Ethernet Series LQFP 64-pin Diagram

## 4.1.18 NuMicro® M487 Ethernet Series LQFP128 Pin Diagram

Corresponding Part Number: M487KIDAE



Figure 4.1-18 NuMicro® M487 Ethernet Series LQFP 128-pin Diagram

#### 4.1.19 NuMicro® M487 Ethernet Series LQFP144 Pin Diagram

Corresponding Part Number: M487JIDAE



Figure 4.1-19 NuMicro® M487 Ethernet Series LQFP 144-pin Diagram

## 4.2 Pin Description

### 4.2.1 M481 Series Pin Description

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

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

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

| 32 Pin | 48 Pin | 64 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------|--------|--------------|------|-------|-----------------------------------------------|
|        | 48     | 1      | PB.6         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | EADC0_CH6    | A    | MFP1  | EADC0 channel 6 analog input.                 |
|        |        |        | EBI_nWRH     | O    | MFP2  | EBI high byte write enable output pin         |
|        |        |        | USCI1_DAT1   | I/O  | MFP4  | USCI1 data 1 pin.                             |
|        |        |        | UART1_RXD    | I    | MFP6  | UART1 data receiver input pin.                |
|        |        |        | SD1_CLK      | O    | MFP7  | SD/SDIO1 clock output pin                     |
|        |        |        | EBI_nCS1     | O    | MFP8  | EBI chip select 1 output pin.                 |
|        |        |        | BPWM1_CH5    | I/O  | MFP10 | BPWM1 channel 5 output/capture input.         |
|        |        |        | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.                      |
|        |        |        | EPWM1_CH5    | I/O  | MFP12 | EPWM1 channel 5 output/capture input.         |
|        | 1      | 2      | INT4         | I    | MFP13 | External interrupt 4 input pin.               |
|        |        |        | ACMP1_O      | O    | MFP15 | Analog comparator 1 output pin.               |
|        |        |        | PB.5         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | EADC0_CH5    | A    | MFP1  | EADC0 channel 5 analog input.                 |
|        |        |        | ACMP1_N      | A    | MFP1  | Analog comparator 1 negative input pin.       |
|        |        |        | EBI_ADR0     | O    | MFP2  | EBI address bus bit 0.                        |
|        |        |        | SD0_DAT3     | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|        |        |        | SPI1_MISO    | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |        |        | I2C0_SCL     | I/O  | MFP6  | I2C0 clock pin.                               |
|        |        |        | UART5_TXD    | O    | MFP7  | UART5 data transmitter output pin.            |
|        | 2      | 3      | USCI1_CTL0   | I/O  | MFP8  | USCI1 control 0 pin.                          |
|        |        |        | SC0_CLK      | O    | MFP9  | Smart Card 0 clock pin.                       |
|        |        |        | I2S0_BCLK    | O    | MFP10 | I2S0 bit clock output pin.                    |
|        |        |        | EPWM0_CH0    | I/O  | MFP11 | EPWM0 channel 0 output/capture input.         |
|        |        |        | TM0          | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |        |        | INT0         | I    | MFP15 | External interrupt 0 input pin.               |
|        |        |        | PB.4         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | EADC0_CH4    | A    | MFP1  | EADC0 channel 4 analog input.                 |

| 32 Pin | 48 Pin | 64 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|--------|--------|------------|------|-------|-----------------------------------------------|
|        |        |        | ACMP1_P1   | A    | MFP1  | Analog comparator 1 positive input 1 pin.     |
|        |        |        | EBI_ADR1   | O    | MFP2  | EBI address bus bit 1.                        |
|        |        |        | SD0_DAT2   | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|        |        |        | SPI1_MOSI  | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |        |        | I2C0_SDA   | I/O  | MFP6  | I2C0 data input/output pin.                   |
|        |        |        | UART5_RXD  | I    | MFP7  | UART5 data receiver input pin.                |
|        |        |        | USCI1_CTL1 | I/O  | MFP8  | USCI1 control 1 pin.                          |
|        |        |        | SC0_DAT    | I/O  | MFP9  | Smart Card 0 data pin.                        |
|        |        |        | I2S0_MCLK  | O    | MFP10 | I2S0 master clock output pin.                 |
|        |        |        | EPWM0_CH1  | I/O  | MFP11 | EPWM0 channel 1 output/capture input.         |
|        |        |        | TM1        | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
|        |        |        | INT1       | I    | MFP15 | External interrupt 1 input pin.               |
|        |        |        | PB.3       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | EADC0_CH3  | A    | MFP1  | EADC0 channel 3 analog input.                 |
|        |        |        | ACMP0_N    | A    | MFP1  | Analog comparator 0 negative input pin.       |
|        |        |        | EBI_ADR2   | O    | MFP2  | EBI address bus bit 2.                        |
|        |        |        | SD0_DAT1   | I/O  | MFP3  | SD/SDIO0 data line bit 1.                     |
|        |        |        | SPI1_CLK   | I/O  | MFP5  | SPI1 serial clock pin.                        |
|        |        |        | UART1_TXD  | O    | MFP6  | UART1 data transmitter output pin.            |
|        |        |        | UART5_nRTS | O    | MFP7  | UART5 request to Send output pin.             |
|        |        |        | USCI1_DAT1 | I/O  | MFP8  | USCI1 data 1 pin.                             |
|        |        |        | SC0_RST    | O    | MFP9  | Smart Card 0 reset pin.                       |
|        |        |        | I2S0_DI    | I    | MFP10 | I2S0 data input pin.                          |
|        |        |        | EPWM0_CH2  | I/O  | MFP11 | EPWM0 channel 2 output/capture input.         |
|        |        |        | TM2        | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|        |        |        | INT2       | I    | MFP15 | External interrupt 2 input pin.               |
|        |        |        | PB.2       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | EADC0_CH2  | A    | MFP1  | EADC0 channel 2 analog input.                 |
|        |        |        | ACMP0_P1   | A    | MFP1  | Analog comparator 0 positive input 1 pin.     |
|        |        |        | OPA0_O     | A    | MFP1  | Operational amplifier 0 output pin.           |
|        |        |        | EBI_ADR3   | O    | MFP2  | EBI address bus bit 3.                        |
|        |        |        | SD0_DAT0   | I/O  | MFP3  | SD/SDIO0 data line bit 0.                     |
|        |        |        | SPI1_SS    | I/O  | MFP5  | SPI1 slave select pin.                        |
|        |        |        | UART1_RXD  | I    | MFP6  | UART1 data receiver input pin.                |

| 32 Pin | 48 Pin | 64 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------|--------|--------------|------|-------|-----------------------------------------------|
|        |        |        | UART5_nCTS   | I    | MFP7  | UART5 clear to Send input pin.                |
|        |        |        | USCI1_DAT0   | I/O  | MFP8  | USCI1 data 0 pin.                             |
|        |        |        | SC0_PWR      | O    | MFP9  | Smart Card 0 power pin.                       |
|        |        |        | I2S0_DO      | O    | MFP10 | I2S0 data output pin.                         |
|        |        |        | EPWM0_CH3    | I/O  | MFP11 | EPWM0 channel 3 output/capture input.         |
|        |        |        | TM3          | I/O  | MFP14 | Timer3 event counter input/toggle output pin. |
|        |        |        | INT3         | I    | MFP15 | External interrupt 3 input pin.               |
|        |        |        | PB.1         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | EADC0_CH1    | A    | MFP1  | EADC0 channel 1 analog input.                 |
|        |        |        | OPA0_N       | A    | MFP1  | Operational amplifier 0 negative input pin.   |
|        |        |        | EBI_ADR8     | O    | MFP2  | EBI address bus bit 8.                        |
|        |        |        | SD0_CLK      | O    | MFP3  | SD/SDIO0 clock output pin                     |
|        |        |        | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin              |
|        |        |        | SPI3_I2SMCLK | I/O  | MFP6  | SPI3 I2S master clock output pin              |
|        |        |        | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.            |
|        |        |        | USCI1_CLK    | I/O  | MFP8  | USCI1 clock pin.                              |
|        |        |        | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                               |
|        |        |        | I2S0_LRCK    | O    | MFP10 | I2S0 left right channel clock output pin.     |
|        |        |        | EPWM0_CH4    | I/O  | MFP11 | EPWM0 channel 4 output/capture input.         |
|        |        |        | EPWM1_CH4    | I/O  | MFP12 | EPWM1 channel 4 output/capture input.         |
|        |        |        | EPWM0_BRAKE0 | I    | MFP13 | EPWM0 Brake 0 input pin.                      |
|        |        |        | PB.0         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | EADC0_CH0    | A    | MFP1  | EADC0 channel 0 analog input.                 |
|        |        |        | OPA0_P       | A    | MFP1  | Operational amplifier 0 positive input pin.   |
|        |        |        | EBI_ADR9     | O    | MFP2  | EBI address bus bit 9.                        |
|        |        |        | SD0_CMD      | I/O  | MFP3  | SD/SDIO0 command/response pin                 |
|        |        |        | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.                |
|        |        |        | SPI0_I2SMCLK | I/O  | MFP8  | SPI0 I2S master clock output pin              |
|        |        |        | I2C1_SDA     | I/O  | MFP9  | I2C1 data input/output pin.                   |
|        |        |        | EPWM0_CH5    | I/O  | MFP11 | EPWM0 channel 5 output/capture input.         |
|        |        |        | EPWM1_CH5    | I/O  | MFP12 | EPWM1 channel 5 output/capture input.         |
|        |        |        | EPWM0_BRAKE1 | I    | MFP13 | EPWM0 Brake 1 input pin.                      |
|        |        |        | PA.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | ACMP0_P0     | A    | MFP1  | Analog comparator 0 positive input 0 pin.     |

| 32 Pin | 48 Pin | 64 Pin | Pin Name       | Type | MFP   | Description                                      |
|--------|--------|--------|----------------|------|-------|--------------------------------------------------|
|        |        |        | EBI_nRD        | O    | MFP2  | EBI read enable output pin.                      |
|        |        |        | SC2_PWR        | O    | MFP3  | Smart Card 2 power pin.                          |
|        |        |        | SPI2_SS        | I/O  | MFP4  | SPI2 slave select pin.                           |
|        |        |        | SD1_DAT3       | I/O  | MFP5  | SD/SDIO1 data line bit 3.                        |
|        |        |        | USCI0_CLK      | I/O  | MFP6  | USCI0 clock pin.                                 |
|        |        |        | I2C2_SCL       | I/O  | MFP7  | I2C2 clock pin.                                  |
|        |        |        | BPWM0_CH0      | I/O  | MFP9  | BPWM0 channel 0 output/capture input.            |
|        |        |        | EPWM0_SYNC_OUT | O    | MFP10 | EPWM0 counter synchronous trigger output pin.    |
|        |        |        | TM0_EXT        | I/O  | MFP13 | Timer0 external capture input/toggle output pin. |
|        |        |        | DAC1_ST        | I    | MFP14 | DAC1 external trigger input.                     |
|        |        | 8 9    | PA.10          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        | ACMP1_P0       | A    | MFP1  | Analog comparator 1 positive input 0 pin.        |
|        |        |        | OPA1_O         | A    | MFP1  | Operational amplifier 1 output pin.              |
|        |        |        | EBI_nWR        | O    | MFP2  | EBI write enable output pin.                     |
|        |        |        | SC2_RST        | O    | MFP3  | Smart Card 2 reset pin.                          |
|        |        |        | SPI2_CLK       | I/O  | MFP4  | SPI2 serial clock pin.                           |
|        |        |        | SD1_DAT2       | I/O  | MFP5  | SD/SDIO1 data line bit 2.                        |
|        |        |        | USCI0_DAT0     | I/O  | MFP6  | USCI0 data 0 pin.                                |
|        |        |        | I2C2_SDA       | I/O  | MFP7  | I2C2 data input/output pin.                      |
|        |        |        | BPWM0_CH1      | I/O  | MFP9  | BPWM0 channel 1 output/capture input.            |
|        |        |        | QE1_INDEX      | I    | MFP10 | Quadrature encoder 1 index input                 |
|        |        |        | ECAP0_IC0      | I    | MFP11 | Enhanced capture unit 0 input 0 pin.             |
|        |        |        | TM1_EXT        | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |        |        | DAC0_ST        | I    | MFP14 | DAC0 external trigger input.                     |
|        |        | 9 10   | PA.9           | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        | OPA1_N         | A    | MFP1  | Operational amplifier 1 negative input pin.      |
|        |        |        | EBI_MCLK       | O    | MFP2  | EBI external clock output pin.                   |
|        |        |        | SC2_DAT        | I/O  | MFP3  | Smart Card 2 data pin.                           |
|        |        |        | SPI2_MISO      | I/O  | MFP4  | SPI2 MISO (Master In, Slave Out) pin.            |
|        |        |        | SD1_DAT1       | I/O  | MFP5  | SD/SDIO1 data line bit 1.                        |
|        |        |        | USCI0_DAT1     | I/O  | MFP6  | USCI0 data 1 pin.                                |
|        |        |        | UART1_TXD      | O    | MFP7  | UART1 data transmitter output pin.               |
|        |        |        | BPWM0_CH2      | I/O  | MFP9  | BPWM0 channel 2 output/capture input.            |
|        |        |        | QE1_A          | I    | MFP10 | Quadrature encoder 1 phase A input               |

| 32 Pin | 48 Pin | 64 Pin | Pin Name        | Type      | MFP   | Description                                                                     |                                    |
|--------|--------|--------|-----------------|-----------|-------|---------------------------------------------------------------------------------|------------------------------------|
|        |        |        | ECAPO_IC1       | I         | MFP11 | Enhanced capture unit 0 input 1 pin.                                            |                                    |
|        |        |        | TM2_EXT         | I/O       | MFP13 | Timer2 external capture input/toggle output pin.                                |                                    |
|        | 10     | 11     | PA.8            | I/O       | MFP0  | General purpose digital I/O pin.                                                |                                    |
|        |        |        | OPA1_P          | A         | MFP1  | Operational amplifier 1 positive input pin.                                     |                                    |
|        |        |        | EBI_ALE         | O         | MFP2  | EBI address latch enable output pin.                                            |                                    |
|        |        |        | SC2_CLK         | O         | MFP3  | Smart Card 2 clock pin.                                                         |                                    |
|        |        |        | SPI2_MOSI       | I/O       | MFP4  | SPI2 MOSI (Master Out, Slave In) pin.                                           |                                    |
|        |        |        | SD1_DAT0        | I/O       | MFP5  | SD/SDIO1 data line bit 0.                                                       |                                    |
|        |        |        | USCI0_CTL1      | I/O       | MFP6  | USCI0 control 1 pin.                                                            |                                    |
|        |        |        | UART1_RXD       | I         | MFP7  | UART1 data receiver input pin.                                                  |                                    |
|        |        |        | BPWM0_CH3       | I/O       | MFP9  | BPWM0 channel 3 output/capture input.                                           |                                    |
|        |        |        | QEI1_B          | I         | MFP10 | Quadrature encoder 1 phase B input                                              |                                    |
|        |        |        | ECAPO_IC2       | I         | MFP11 | Enhanced capture unit 0 input 2 pin.                                            |                                    |
|        |        |        | TM3_EXT         | I/O       | MFP13 | Timer3 external capture input/toggle output pin.                                |                                    |
|        |        |        | INT4            | I         | MFP15 | External interrupt 4 input pin.                                                 |                                    |
|        | 12     |        | PF.6            | I/O       | MFP0  | General purpose digital I/O pin.                                                |                                    |
|        |        |        | EBI_ADR19       | O         | MFP2  | EBI address bus bit 19.                                                         |                                    |
|        |        |        | SC0_CLK         | O         | MFP3  | Smart Card 0 clock pin.                                                         |                                    |
|        |        |        | I2S0_LRCK       | O         | MFP4  | I2S0 left right channel clock output pin.                                       |                                    |
|        |        |        | SPI0_MOSI       | I/O       | MFP5  | SPI0 MOSI (Master Out, Slave In) pin.                                           |                                    |
|        |        |        | UART4_RXD       | I         | MFP6  | UART4 data receiver input pin.                                                  |                                    |
|        |        |        | EBI_nCS0        | O         | MFP7  | EBI chip select 0 output pin.                                                   |                                    |
|        |        |        | TAMPER0         | I/O       | MFP10 | TAMPER detector loop pin 0.                                                     |                                    |
|        |        | 13     | V <sub>DD</sub> | P         | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |                                    |
|        | 7      | 11     | PF.5            | I/O       | MFP0  | General purpose digital I/O pin.                                                |                                    |
|        |        |        | UART2_RXD       | I         | MFP2  | UART2 data receiver input pin.                                                  |                                    |
|        |        |        | UART2_nCTS      | I         | MFP4  | UART2 clear to Send input pin.                                                  |                                    |
|        |        |        | BPWM0_CH4       | I/O       | MFP8  | BPWM0 channel 4 output/capture input.                                           |                                    |
|        |        |        | EPWM0_SYNC_OUT  | O         | MFP9  | EPWM0 counter synchronous trigger output pin.                                   |                                    |
|        |        |        | X32_IN          | I         | MFP10 | External 32.768 kHz crystal input pin.                                          |                                    |
|        |        |        | EADC0_ST        | I         | MFP11 | EADC0 external trigger input.                                                   |                                    |
|        | 8      | 12     | 15              | PF.4      | I/O   | MFP0                                                                            | General purpose digital I/O pin.   |
|        |        |        |                 | UART2_TXD | O     | MFP2                                                                            | UART2 data transmitter output pin. |

| 32 Pin | 48 Pin | 64 Pin | Pin Name    | Type | MFP   | Description                                        |
|--------|--------|--------|-------------|------|-------|----------------------------------------------------|
|        |        |        | UART2_nRTS  | O    | MFP4  | UART2 request to Send output pin.                  |
|        |        |        | BPWM0_CH5   | I/O  | MFP8  | BPWM0 channel 5 output/capture input.              |
|        |        |        | X32_OUT     | O    | MFP10 | External 32.768 kHz crystal output pin.            |
| 9      | 13     | 16     | PF.3        | I/O  | MFP0  | General purpose digital I/O pin.                   |
|        |        |        | EBI_nCS0    | O    | MFP2  | EBI chip select 0 output pin.                      |
|        |        |        | UART0_TXD   | O    | MFP3  | UART0 data transmitter output pin.                 |
|        |        |        | I2C0_SCL    | I/O  | MFP4  | I2C0 clock pin.                                    |
|        |        |        | XT1_IN      | I    | MFP10 | External 4~24 MHz (high speed) crystal input pin.  |
|        |        |        | BPWM1_CH0   | I/O  | MFP11 | BPWM1 channel 0 output/capture input.              |
| 10     | 14     | 17     | PF.2        | I/O  | MFP0  | General purpose digital I/O pin.                   |
|        |        |        | EBI_nCS1    | O    | MFP2  | EBI chip select 1 output pin.                      |
|        |        |        | UART0_RXD   | I    | MFP3  | UART0 data receiver input pin.                     |
|        |        |        | I2C0_SDA    | I/O  | MFP4  | I2C0 data input/output pin.                        |
|        |        |        | QSPI0_CLK   | I/O  | MFP5  | Quad SPI0 serial clock pin.                        |
|        |        |        | XT1_OUT     | O    | MFP10 | External 4~24 MHz (high speed) crystal output pin. |
|        |        |        | BPWM1_CH1   | I/O  | MFP11 | BPWM1 channel 1 output/capture input.              |
|        |        | 18     | PC.7        | I/O  | MFP0  | General purpose digital I/O pin.                   |
|        |        |        | EBI_AD9     | I/O  | MFP2  | EBI address/data bus bit 9.                        |
|        |        |        | SPI1_MISO   | I/O  | MFP4  | SPI1 MISO (Master In, Slave Out) pin.              |
|        |        |        | UART4_TXD   | O    | MFP5  | UART4 data transmitter output pin.                 |
|        |        |        | SC2_PWR     | O    | MFP6  | Smart Card 2 power pin.                            |
|        |        |        | UART0_nCTS  | I    | MFP7  | UART0 clear to Send input pin.                     |
|        |        |        | I2C1_SMBAL  | O    | MFP8  | I2C1 SMBus SMBALTER pin                            |
|        |        |        | EPWM1_CH2   | I/O  | MFP11 | EPWM1 channel 2 output/capture input.              |
|        |        |        | BPWM1_CH0   | I/O  | MFP12 | BPWM1 channel 0 output/capture input.              |
|        |        |        | TM0         | I/O  | MFP14 | Timer0 event counter input/toggle output pin.      |
|        |        | 19     | INT3        | I    | MFP15 | External interrupt 3 input pin.                    |
|        |        |        | PC.6        | I/O  | MFP0  | General purpose digital I/O pin.                   |
|        |        |        | EBI_AD8     | I/O  | MFP2  | EBI address/data bus bit 8.                        |
|        |        |        | SPI1_MOSI   | I/O  | MFP4  | SPI1 MOSI (Master Out, Slave In) pin.              |
|        |        |        | UART4_RXD   | I    | MFP5  | UART4 data receiver input pin.                     |
|        |        |        | SC2_RST     | O    | MFP6  | Smart Card 2 reset pin.                            |
|        |        |        | UART0_nRTS  | O    | MFP7  | UART0 request to Send output pin.                  |
|        |        |        | I2C1_SMBSUS | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)          |

| 32 Pin | 48 Pin | 64 Pin          | Pin Name    | Type | MFP   | Description                                                                     |
|--------|--------|-----------------|-------------|------|-------|---------------------------------------------------------------------------------|
|        |        |                 | EPWM1_CH3   | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                                           |
|        |        |                 | BPWM1_CH1   | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                                           |
|        |        |                 | TM1         | I/O  | MFP14 | Timer1 event counter input/toggle output pin.                                   |
|        |        |                 | INT2        | I    | MFP15 | External interrupt 2 input pin.                                                 |
|        | 15     | 20              | PA.7        | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |                 | EBI_AD7     | I/O  | MFP2  | EBI address/data bus bit 7.                                                     |
|        |        |                 | SPI1_CLK    | I/O  | MFP4  | SPI1 serial clock pin.                                                          |
|        |        |                 | SC2_DAT     | I/O  | MFP6  | Smart Card 2 data pin.                                                          |
|        |        |                 | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.                                              |
|        |        |                 | I2C1_SCL    | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |        |                 | EPWM1_CH4   | I/O  | MFP11 | EPWM1 channel 4 output/capture input.                                           |
|        |        |                 | BPWM1_CH2   | I/O  | MFP12 | BPWM1 channel 2 output/capture input.                                           |
|        |        |                 | ACMP0_WLAT  | I    | MFP13 | Analog comparator 0 window latch input pin                                      |
|        |        |                 | TM2         | I/O  | MFP14 | Timer2 event counter input/toggle output pin.                                   |
|        |        |                 | INT1        | I    | MFP15 | External interrupt 1 input pin.                                                 |
|        | 16     | 21              | PA.6        | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |                 | EBI_AD6     | I/O  | MFP2  | EBI address/data bus bit 6.                                                     |
|        |        |                 | SPI1_SS     | I/O  | MFP4  | SPI1 slave select pin.                                                          |
|        |        |                 | SD1_nCD     | I    | MFP5  | SD/SDIO1 card detect input pin                                                  |
|        |        |                 | SC2_CLK     | O    | MFP6  | Smart Card 2 clock pin.                                                         |
|        |        |                 | UART0_RXD   | I    | MFP7  | UART0 data receiver input pin.                                                  |
|        |        |                 | I2C1_SDA    | I/O  | MFP8  | I2C1 data input/output pin.                                                     |
|        |        |                 | EPWM1_CH5   | I/O  | MFP11 | EPWM1 channel 5 output/capture input.                                           |
|        |        |                 | BPWM1_CH3   | I/O  | MFP12 | BPWM1 channel 3 output/capture input.                                           |
|        |        |                 | ACMP1_WLAT  | I    | MFP13 | Analog comparator 1 window latch input pin                                      |
|        |        |                 | TM3         | I/O  | MFP14 | Timer3 event counter input/toggle output pin.                                   |
|        |        |                 | INT0        | I    | MFP15 | External interrupt 0 input pin.                                                 |
|        | 22     | V <sub>ss</sub> |             | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        | 23     | V <sub>DD</sub> |             | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        | 24     | LDO_CAP         |             | A    | MFP0  | LDO output pin.                                                                 |
|        | 17     | 25              | PA.5        | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |                 | SPIM_D2     | I/O  | MFP2  | SPIM data 2 pin for Quad Mode I/O.                                              |
|        |        |                 | QSPI0_MISO1 | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin.                                     |

| 32 Pin | 48 Pin | 64 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|--------------|------|-------|---------------------------------------------|
|        |        |        | SPI1_I2SMCLK | I/O  | MFP4  | SPI1 I2S master clock output pin            |
|        |        |        | SD1_CMD      | I/O  | MFP5  | SD/SDIO1 command/response pin               |
|        |        |        | SC2_nCD      | I    | MFP6  | Smart Card 2 card detect pin.               |
|        |        |        | UART0_nCTS   | I    | MFP7  | UART0 clear to Send input pin.              |
|        |        |        | UART5_TXD    | O    | MFP8  | UART5 data transmitter output pin.          |
|        |        |        | I2C0_SCL     | I/O  | MFP9  | I2C0 clock pin.                             |
|        |        |        | BPWM0_CH5    | I/O  | MFP12 | BPWM0 channel 5 output/capture input.       |
|        |        |        | EPWM0_CH0    | I/O  | MFP13 | EPWM0 channel 0 output/capture input.       |
|        |        |        | QEIO_INDEX   | I    | MFP14 | Quadrature encoder 0 index input            |
|        |        | 18     | PA.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | SPIM_D3      | I/O  | MFP2  | SPIM data 3 pin for Quad Mode I/O.          |
|        |        |        | QSPI0_MOSI1  | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |        |        | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin            |
|        |        |        | SD1_CLK      | O    | MFP5  | SD/SDIO1 clock output pin                   |
|        |        |        | SC0_nCD      | I    | MFP6  | Smart Card 0 card detect pin.               |
|        |        |        | UART0_nRTS   | O    | MFP7  | UART0 request to Send output pin.           |
|        |        |        | UART5_RXD    | I    | MFP8  | UART5 data receiver input pin.              |
|        |        |        | I2C0_SDA     | I/O  | MFP9  | I2C0 data input/output pin.                 |
|        |        |        | BPWM0_CH4    | I/O  | MFP12 | BPWM0 channel 4 output/capture input.       |
|        |        |        | EPWM0_CH1    | I/O  | MFP13 | EPWM0 channel 1 output/capture input.       |
|        |        |        | QEIO_A       | I    | MFP14 | Quadrature encoder 0 phase A input          |
|        |        | 19     | PA.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | SPIM_SS      | I/O  | MFP2  | SPIM slave select pin.                      |
|        |        |        | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                 |
|        |        |        | SPI0_SS      | I/O  | MFP4  | SPI0 slave select pin.                      |
|        |        |        | SD1_DAT3     | I/O  | MFP5  | SD/SDIO1 data line bit 3.                   |
|        |        |        | SC0_PWR      | O    | MFP6  | Smart Card 0 power pin.                     |
|        |        |        | UART4_TXD    | O    | MFP7  | UART4 data transmitter output pin.          |
|        |        |        | UART1_TXD    | O    | MFP8  | UART1 data transmitter output pin.          |
|        |        |        | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |        |        | BPWM0_CH3    | I/O  | MFP12 | BPWM0 channel 3 output/capture input.       |
|        |        |        | EPWM0_CH2    | I/O  | MFP13 | EPWM0 channel 2 output/capture input.       |
|        |        |        | QEIO_B       | I    | MFP14 | Quadrature encoder 0 phase B input          |
| 12     | 20     | 28     | PA.2         | I/O  | MFP0  | General purpose digital I/O pin.            |

| 32 Pin | 48 Pin | 64 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------|--------|-------------|------|-------|---------------------------------------------|
|        |        |        | SPIM_CLK    | I/O  | MFP2  | SPIM serial clock pin.                      |
|        |        |        | QSPI0_CLK   | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |        |        | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                      |
|        |        |        | SD1_DAT2    | I/O  | MFP5  | SD/SDIO1 data line bit 2.                   |
|        |        |        | SC0_RST     | O    | MFP6  | Smart Card 0 reset pin.                     |
|        |        |        | UART4_RXD   | I    | MFP7  | UART4 data receiver input pin.              |
|        |        |        | UART1_RXD   | I    | MFP8  | UART1 data receiver input pin.              |
|        |        |        | I2C1_SDA    | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |        |        | BPWM0_CH2   | I/O  | MFP12 | BPWM0 channel 2 output/capture input.       |
|        |        |        | EPWM0_CH3   | I/O  | MFP13 | EPWM0 channel 3 output/capture input.       |
|        |        |        | PA.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | SPIM_MISO   | I/O  | MFP2  | SPIM MISO (Master In, Slave Out) pin.       |
|        |        |        | QSPI0_MISO0 | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |        |        | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|        |        |        | SD1_DAT1    | I/O  | MFP5  | SD/SDIO1 data line bit 1.                   |
|        |        |        | SC0_DAT     | I/O  | MFP6  | Smart Card 0 data pin.                      |
|        |        |        | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.          |
|        |        |        | UART1_nCTS  | I    | MFP8  | UART1 clear to Send input pin.              |
|        |        |        | I2C2_SCL    | I/O  | MFP9  | I2C2 clock pin.                             |
|        |        |        | BPWM0_CH1   | I/O  | MFP12 | BPWM0 channel 1 output/capture input.       |
|        |        |        | EPWM0_CH4   | I/O  | MFP13 | EPWM0 channel 4 output/capture input.       |
|        |        |        | DAC1_ST     | I    | MFP15 | DAC1 external trigger input.                |
|        |        |        | PA.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | SPIM_MOSI   | I/O  | MFP2  | SPIM MOSI (Master Out, Slave In) pin.       |
|        |        |        | QSPI0_MOSI0 | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|        |        |        | SPI0_MOSI   | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.       |
|        |        |        | SD1_DAT0    | I/O  | MFP5  | SD/SDIO1 data line bit 0.                   |
|        |        |        | SC0_CLK     | O    | MFP6  | Smart Card 0 clock pin.                     |
|        |        |        | UART0_RXD   | I    | MFP7  | UART0 data receiver input pin.              |
|        |        |        | UART1_nRTS  | O    | MFP8  | UART1 request to Send output pin.           |
|        |        |        | I2C2_SDA    | I/O  | MFP9  | I2C2 data input/output pin.                 |
|        |        |        | BPWM0_CH0   | I/O  | MFP12 | BPWM0 channel 0 output/capture input.       |
|        |        |        | EPWM0_CH5   | I/O  | MFP13 | EPWM0 channel 5 output/capture input.       |
|        |        |        | DAC0_ST     | I    | MFP15 | DAC0 external trigger input.                |

| 32 Pin | 48 Pin | 64 Pin       | Pin Name          | Type  | MFP                                         | Description                                                                                          |
|--------|--------|--------------|-------------------|-------|---------------------------------------------|------------------------------------------------------------------------------------------------------|
| 15     | 23     | 31           | V <sub>DDIO</sub> | P     | MFP0                                        | Power supply for PA.0~PA.5.                                                                          |
| 16     | 24     | 32           | nRESET            | I     | MFP0                                        | External reset input: active LOW, with an internal pull-up. Set this pin low reset to initial state. |
| 17     | 25     | 33           | PF.0              | I/O   | MFP0                                        | General purpose digital I/O pin.                                                                     |
|        |        |              | UART1_TXD         | O     | MFP2                                        | UART1 data transmitter output pin.                                                                   |
|        |        |              | I2C1_SCL          | I/O   | MFP3                                        | I2C1 clock pin.                                                                                      |
|        |        |              | BPWM1_CH0         | I/O   | MFP12                                       | BPWM1 channel 0 output/capture input.                                                                |
|        |        |              | ICE_DAT           | O     | MFP14                                       | Serial wired debugger data pin.                                                                      |
| 18     | 26     | 34           | PF.1              | I/O   | MFP0                                        | General purpose digital I/O pin.                                                                     |
|        |        |              | UART1_RXD         | I     | MFP2                                        | UART1 data receiver input pin.                                                                       |
|        |        |              | I2C1_SDA          | I/O   | MFP3                                        | I2C1 data input/output pin.                                                                          |
|        |        |              | BPWM1_CH1         | I/O   | MFP12                                       | BPWM1 channel 1 output/capture input.                                                                |
|        |        |              | ICE_CLK           | I     | MFP14                                       | Serial wired debugger clock pin.                                                                     |
| 27     | 35     | PC.5         | I/O               | MFP0  | General purpose digital I/O pin.            |                                                                                                      |
|        |        | EBI_AD5      | I/O               | MFP2  | EBI address/data bus bit 5.                 |                                                                                                      |
|        |        | SPIM_D2      | I/O               | MFP3  | SPIM data 2 pin for Quad Mode I/O.          |                                                                                                      |
|        |        | QSPI0_MISO1  | I/O               | MFP4  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |                                                                                                      |
|        |        | UART2_TXD    | O                 | MFP8  | UART2 data transmitter output pin.          |                                                                                                      |
|        |        | I2C1_SCL     | I/O               | MFP9  | I2C1 clock pin.                             |                                                                                                      |
|        |        | UART4_TXD    | O                 | MFP11 | UART4 data transmitter output pin.          |                                                                                                      |
|        |        | EPWM1_CH0    | I/O               | MFP12 | EPWM1 channel 0 output/capture input.       |                                                                                                      |
| 28     | 36     | PC.4         | I/O               | MFP0  | General purpose digital I/O pin.            |                                                                                                      |
|        |        | EBI_AD4      | I/O               | MFP2  | EBI address/data bus bit 4.                 |                                                                                                      |
|        |        | SPIM_D3      | I/O               | MFP3  | SPIM data 3 pin for Quad Mode I/O.          |                                                                                                      |
|        |        | QSPI0_MOSI1  | I/O               | MFP4  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |                                                                                                      |
|        |        | SC1_nCD      | I                 | MFP5  | Smart Card 1 card detect pin.               |                                                                                                      |
|        |        | I2S0_BCLK    | O                 | MFP6  | I2S0 bit clock output pin.                  |                                                                                                      |
|        |        | SPI1_I2SMCLK | I/O               | MFP7  | SPI1 I2S master clock output pin            |                                                                                                      |
|        |        | UART2_RXD    | I                 | MFP8  | UART2 data receiver input pin.              |                                                                                                      |
|        |        | I2C1_SDA     | I/O               | MFP9  | I2C1 data input/output pin.                 |                                                                                                      |
|        |        | UART4_RXD    | I                 | MFP11 | UART4 data receiver input pin.              |                                                                                                      |
|        | 29     | 37           | EPWM1_CH1         | I/O   | MFP12                                       | EPWM1 channel 1 output/capture input.                                                                |
|        |        |              | PC.3              | I/O   | MFP0                                        | General purpose digital I/O pin.                                                                     |
|        |        |              | EBI_AD3           | I/O   | MFP2                                        | EBI address/data bus bit 3.                                                                          |

| 32 Pin | 48 Pin | 64 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------|--------|-------------|------|-------|---------------------------------------------|
|        |        |        | SPIM_SS     | I/O  | MFP3  | SPIM slave select pin.                      |
|        |        |        | QSPI0_SS    | I/O  | MFP4  | Quad SPI0 slave select pin.                 |
|        |        |        | SC1_PWR     | O    | MFP5  | Smart Card 1 power pin.                     |
|        |        |        | I2S0_MCLK   | O    | MFP6  | I2S0 master clock output pin.               |
|        |        |        | SPI1_MISO   | I/O  | MFP7  | SPI1 MISO (Master In, Slave Out) pin.       |
|        |        |        | UART2_nRTS  | O    | MFP8  | UART2 request to Send output pin.           |
|        |        |        | I2C0_SMBAL  | O    | MFP9  | I2C0 SMBus SMBALTER pin                     |
|        |        |        | UART3_TXD   | O    | MFP11 | UART3 data transmitter output pin.          |
|        |        |        | EPWM1_CH2   | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        |        | 30     | PC.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | EBI_AD2     | I/O  | MFP2  | EBI address/data bus bit 2.                 |
|        |        |        | SPIM_CLK    | I/O  | MFP3  | SPIM serial clock pin.                      |
|        |        |        | QSPI0_CLK   | I/O  | MFP4  | Quad SPI0 serial clock pin.                 |
|        |        |        | SC1_RST     | O    | MFP5  | Smart Card 1 reset pin.                     |
|        |        |        | I2S0_DI     | I    | MFP6  | I2S0 data input pin.                        |
|        |        |        | SPI1_MOSI   | I/O  | MFP7  | SPI1 MOSI (Master Out, Slave In) pin.       |
|        |        |        | UART2_nCTS  | I    | MFP8  | UART2 clear to Send input pin.              |
|        |        |        | I2C0_SMBSUS | O    | MFP9  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |        |        | UART3_RXD   | I    | MFP11 | UART3 data receiver input pin.              |
|        |        |        | EPWM1_CH3   | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        |        | 31     | PC.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | EBI_AD1     | I/O  | MFP2  | EBI address/data bus bit 1.                 |
|        |        |        | SPIM_MISO   | I/O  | MFP3  | SPIM MISO (Master In, Slave Out) pin.       |
|        |        |        | QSPI0_MISO0 | I/O  | MFP4  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |        |        | SC1_DAT     | I/O  | MFP5  | Smart Card 1 data pin.                      |
|        |        |        | I2S0_DO     | O    | MFP6  | I2S0 data output pin.                       |
|        |        |        | SPI1_CLK    | I/O  | MFP7  | SPI1 serial clock pin.                      |
|        |        |        | UART2_TXD   | O    | MFP8  | UART2 data transmitter output pin.          |
|        |        |        | I2C0_SCL    | I/O  | MFP9  | I2C0 clock pin.                             |
|        |        |        | EPWM1_CH4   | I/O  | MFP12 | EPWM1 channel 4 output/capture input.       |
|        |        |        | ACMP0_O     | O    | MFP14 | Analog comparator 0 output pin.             |
|        |        | 40     | PC.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | EBI_AD0     | I/O  | MFP2  | EBI address/data bus bit 0.                 |
|        |        |        | SPIM_MOSI   | I/O  | MFP3  | SPIM MOSI (Master Out, Slave In) pin.       |

| 32 Pin | 48 Pin | 64 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------|--------|-------------|------|-------|---------------------------------------------|
|        |        |        | QSPI0_MOSI0 | I/O  | MFP4  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|        |        |        | SC1_CLK     | O    | MFP5  | Smart Card 1 clock pin.                     |
|        |        |        | I2S0_LRCK   | O    | MFP6  | I2S0 left right channel clock output pin.   |
|        |        |        | SPI1_SS     | I/O  | MFP7  | SPI1 slave select pin.                      |
|        |        |        | UART2_RXD   | I    | MFP8  | UART2 data receiver input pin.              |
|        |        |        | I2C0_SDA    | I/O  | MFP9  | I2C0 data input/output pin.                 |
|        |        |        | EPWM1_CH5   | I/O  | MFP12 | EPWM1 channel 5 output/capture input.       |
|        |        |        | ACMP1_O     | O    | MFP14 | Analog comparator 1 output pin.             |
|        |        | 41     | PD.3        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | EBI_AD10    | I/O  | MFP2  | EBI address/data bus bit 10.                |
|        |        |        | USCI0_CTL1  | I/O  | MFP3  | USCI0 control 1 pin.                        |
|        |        |        | SPI0_SS     | I/O  | MFP4  | SPI0 slave select pin.                      |
|        |        |        | UART3_nRTS  | O    | MFP5  | UART3 request to Send output pin.           |
|        |        |        | USCI1_CTL0  | I/O  | MFP6  | USCI1 control 0 pin.                        |
|        |        |        | SC2_PWR     | O    | MFP7  | Smart Card 2 power pin.                     |
|        |        |        | SC1_nCD     | I    | MFP8  | Smart Card 1 card detect pin.               |
|        |        |        | UART0_TXD   | O    | MFP9  | UART0 data transmitter output pin.          |
|        |        | 42     | PD.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | EBI_AD11    | I/O  | MFP2  | EBI address/data bus bit 11.                |
|        |        |        | USCI0_DAT1  | I/O  | MFP3  | USCI0 data 1 pin.                           |
|        |        |        | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                      |
|        |        |        | UART3_nCTS  | I    | MFP5  | UART3 clear to Send input pin.              |
|        |        |        | SC2_RST     | O    | MFP7  | Smart Card 2 reset pin.                     |
|        |        |        | UART0_RXD   | I    | MFP9  | UART0 data receiver input pin.              |
|        |        | 43     | PD.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | EBI_AD12    | I/O  | MFP2  | EBI address/data bus bit 12.                |
|        |        |        | USCI0_DAT0  | I/O  | MFP3  | USCI0 data 0 pin.                           |
|        |        |        | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|        |        |        | UART3_TXD   | O    | MFP5  | UART3 data transmitter output pin.          |
|        |        |        | I2C2_SCL    | I/O  | MFP6  | I2C2 clock pin.                             |
|        |        |        | SC2_DAT     | I/O  | MFP7  | Smart Card 2 data pin.                      |
|        |        | 44     | PD.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        | EBI_AD13    | I/O  | MFP2  | EBI address/data bus bit 13.                |
|        |        |        | USCI0_CLK   | I/O  | MFP3  | USCI0 clock pin.                            |

| 32 Pin | 48 Pin | 64 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|--------|--------|------------|------|-------|-----------------------------------------------|
|        |        |        | SPI0_MOSI  | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.         |
|        |        |        | UART3_RXD  | I    | MFP5  | UART3 data receiver input pin.                |
|        |        |        | I2C2_SDA   | I/O  | MFP6  | I2C2 data input/output pin.                   |
|        |        |        | SC2_CLK    | O    | MFP7  | Smart Card 2 clock pin.                       |
|        |        |        | TM2        | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
| 21     | 33     | 45     | PA.12      | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | I2S0_BCLK  | O    | MFP2  | I2S0 bit clock output pin.                    |
|        |        |        | UART4_TXD  | O    | MFP3  | UART4 data transmitter output pin.            |
|        |        |        | I2C1_SCL   | I/O  | MFP4  | I2C1 clock pin.                               |
|        |        |        | SPI2_SS    | I/O  | MFP5  | SPI2 slave select pin.                        |
|        |        |        | SC2_PWR    | O    | MFP7  | Smart Card 2 power pin.                       |
|        |        |        | BPWM1_CH2  | I/O  | MFP11 | BPWM1 channel 2 output/capture input.         |
|        |        |        | QEI1_INDEX | I    | MFP12 | Quadrature encoder 1 index input              |
| 22     | 34     | 46     | PA.13      | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | I2S0_MCLK  | O    | MFP2  | I2S0 master clock output pin.                 |
|        |        |        | UART4_RXD  | I    | MFP3  | UART4 data receiver input pin.                |
|        |        |        | I2C1_SDA   | I/O  | MFP4  | I2C1 data input/output pin.                   |
|        |        |        | SPI2_CLK   | I/O  | MFP5  | SPI2 serial clock pin.                        |
|        |        |        | SC2_RST    | O    | MFP7  | Smart Card 2 reset pin.                       |
|        |        |        | BPWM1_CH3  | I/O  | MFP11 | BPWM1 channel 3 output/capture input.         |
|        |        |        | QEI1_A     | I    | MFP12 | Quadrature encoder 1 phase A input            |
| 23     | 35     | 47     | PA.14      | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | I2S0_DI    | I    | MFP2  | I2S0 data input pin.                          |
|        |        |        | UART0_TXD  | O    | MFP3  | UART0 data transmitter output pin.            |
|        |        |        | SPI2_MISO  | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.         |
|        |        |        | I2C2_SCL   | I/O  | MFP6  | I2C2 clock pin.                               |
|        |        |        | SC2_DAT    | I/O  | MFP7  | Smart Card 2 data pin.                        |
|        |        |        | BPWM1_CH4  | I/O  | MFP11 | BPWM1 channel 4 output/capture input.         |
|        |        |        | QEI1_B     | I    | MFP12 | Quadrature encoder 1 phase B input            |
| 24     | 36     | 48     | PA.15      | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        | I2S0_DO    | O    | MFP2  | I2S0 data output pin.                         |
|        |        |        | UART0_RXD  | I    | MFP3  | UART0 data receiver input pin.                |
|        |        |        | SPI2_MOSI  | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.         |
|        |        |        | I2C2_SDA   | I/O  | MFP6  | I2C2 data input/output pin.                   |

| 32 Pin | 48 Pin | 64 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        | SC2_CLK         | O    | MFP7  | Smart Card 2 clock pin.                                                         |
|        |        |        | BPWM1_CH5       | I/O  | MFP11 | BPWM1 channel 5 output/capture input.                                           |
|        |        |        | EPWM0_SYNC_IN   | I    | MFP12 | EPWM0 counter synchronous trigger input pin.                                    |
| 25     | 37     | 49     | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 26     | 38     | 50     | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |
| 27     | 39     | 51     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | PC.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |        |        | SC1_nCD         | I    | MFP3  | Smart Card 1 card detect pin.                                                   |
|        |        |        | SPI0_I2SMCLK    | I/O  | MFP4  | SPI0 I2S master clock output pin                                                |
|        |        |        | USCI0_CTL0      | I/O  | MFP5  | USCI0 control 0 pin.                                                            |
|        |        |        | QSPI0_CLK       | I/O  | MFP6  | Quad SPI0 serial clock pin.                                                     |
|        |        |        | EPWM0_SYNC_IN   | I    | MFP11 | EPWM0 counter synchronous trigger input pin.                                    |
|        |        |        | TM1             | I/O  | MFP13 | Timer1 event counter input/toggle output pin.                                   |
| 28     |        |        | PB.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        | EADC0_CH15      | A    | MFP1  | EADC0 channel 15 analog input.                                                  |
|        |        |        | EBI_AD12        | I/O  | MFP2  | EBI address/data bus bit 12.                                                    |
|        |        |        | SC1_PWR         | O    | MFP3  | Smart Card 1 power pin.                                                         |
|        |        |        | SPI0_SS         | I/O  | MFP4  | SPI0 slave select pin.                                                          |
|        |        |        | USCI0_CTL1      | I/O  | MFP5  | USCI0 control 1 pin.                                                            |
|        |        |        | UART0_nCTS      | I    | MFP6  | UART0 clear to Send input pin.                                                  |
|        |        |        | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |        |        | I2C2_SMBAL      | O    | MFP8  | I2C2 SMBus SMBALTER pin                                                         |
|        |        |        | EPWM1_CH0       | I/O  | MFP11 | EPWM1 channel 0 output/capture input.                                           |
|        |        |        | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
| 29     |        |        | PB.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        | EADC0_CH14      | A    | MFP1  | EADC0 channel 14 analog input.                                                  |
|        |        |        | EBI_AD13        | I/O  | MFP2  | EBI address/data bus bit 13.                                                    |
|        |        |        | SC1_RST         | O    | MFP3  | Smart Card 1 reset pin.                                                         |
|        |        |        | SPI0_CLK        | I/O  | MFP4  | SPI0 serial clock pin.                                                          |
|        |        |        | USCI0_DAT1      | I/O  | MFP5  | USCI0 data 1 pin.                                                               |
|        |        |        | UART0_nRTS      | O    | MFP6  | UART0 request to Send output pin.                                               |
|        |        |        | UART3_RXD       | I    | MFP7  | UART3 data receiver input pin.                                                  |

| 32 Pin | 48 Pin | 64 Pin | Pin Name         | Type | MFP   | Description                                      |
|--------|--------|--------|------------------|------|-------|--------------------------------------------------|
|        |        |        | I2C2_SMBSUS      | O    | MFP8  | I2C2 SMBus SMBSUS pin (PMBus CONTROL pin)        |
|        |        |        | EPWM1_CH1        | I/O  | MFP11 | EPWM1 channel 1 output/capture input.            |
|        |        |        | TM1_EXT          | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |        |        | CLKO             | O    | MFP14 | Clock Out                                        |
|        |        |        | PB.13            | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        | EADC0_CH13       | A    | MFP1  | EADC0 channel 13 analog input.                   |
|        |        |        | DAC1_OUT         | A    | MFP1  | DAC1 channel analog output.                      |
|        |        |        | ACMP0_P3         | A    | MFP1  | Analog comparator 0 positive input 3 pin.        |
|        |        |        | ACMP1_P3         | A    | MFP1  | Analog comparator 1 positive input 3 pin.        |
|        |        |        | EBI_AD14         | I/O  | MFP2  | EBI address/data bus bit 14.                     |
|        |        |        | SC1_DAT          | I/O  | MFP3  | Smart Card 1 data pin.                           |
|        |        |        | SPI0_MISO        | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.            |
|        |        |        | USCI0_DAT0       | I/O  | MFP5  | USCI0 data 0 pin.                                |
|        |        |        | UART0_TXD        | O    | MFP6  | UART0 data transmitter output pin.               |
|        |        |        | UART3_nRTS       | O    | MFP7  | UART3 request to Send output pin.                |
|        |        |        | I2C2_SCL         | I/O  | MFP8  | I2C2 clock pin.                                  |
|        |        |        | EPWM1_CH2        | I/O  | MFP11 | EPWM1 channel 2 output/capture input.            |
|        |        |        | TM2_EXT          | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|        |        |        | PB.12            | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        | EADC0_CH12       | A    | MFP1  | EADC0 channel 12 analog input.                   |
|        |        |        | DAC0_OUT         | A    | MFP1  | DAC0 channel analog output.                      |
|        |        |        | ACMP0_P2         | A    | MFP1  | Analog comparator 0 positive input 2 pin.        |
|        |        |        | ACMP1_P2         | A    | MFP1  | Analog comparator 1 positive input 2 pin.        |
|        |        |        | EBI_AD15         | I/O  | MFP2  | EBI address/data bus bit 15.                     |
|        |        |        | SC1_CLK          | O    | MFP3  | Smart Card 1 clock pin.                          |
|        |        |        | SPI0_MOSI        | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.            |
|        |        |        | USCI0_CLK        | I/O  | MFP5  | USCI0 clock pin.                                 |
|        |        |        | UART0_RXD        | I    | MFP6  | UART0 data receiver input pin.                   |
|        |        |        | UART3_nCTS       | I    | MFP7  | UART3 clear to Send input pin.                   |
|        |        |        | I2C2_SDA         | I/O  | MFP8  | I2C2 data input/output pin.                      |
|        |        |        | SD0_nCD          | I    | MFP9  | SD/SDIO0 card detect input pin                   |
|        |        |        | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.            |
|        |        |        | TM3_EXT          | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
| 32     | 45     | 57     | AV <sub>DD</sub> | P    | MFP0  | Power supply for internal analog circuit.        |

| 32 Pin | 48 Pin | 64 Pin | Pin Name         | Type | MFP   | Description                                                                                |
|--------|--------|--------|------------------|------|-------|--------------------------------------------------------------------------------------------|
|        |        | 58     | V <sub>REF</sub> | A    | MFP0  | ADC reference voltage input.<br>Note: This pin needs to be connected with a 1uF capacitor. |
|        | 46     | 59     | A <sub>VSS</sub> | P    | MFP0  | Ground pin for analog circuit.                                                             |
|        |        | 60     | PB.11            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        | EADC0_CH11       | A    | MFP1  | EADC0 channel 11 analog input.                                                             |
|        |        |        | EBI_ADR16        | O    | MFP2  | EBI address bus bit 16.                                                                    |
|        |        |        | UART0_nCTS       | I    | MFP5  | UART0 clear to Send input pin.                                                             |
|        |        |        | UART4_TXD        | O    | MFP6  | UART4 data transmitter output pin.                                                         |
|        |        |        | I2C1_SCL         | I/O  | MFP7  | I2C1 clock pin.                                                                            |
|        |        |        | SPI0_I2SMCLK     | I/O  | MFP9  | SPI0 I2S master clock output pin                                                           |
|        |        |        | BPWM1_CH0        | I/O  | MFP10 | BPWM1 channel 0 output/capture input.                                                      |
|        |        |        | SPI3_CLK         | I/O  | MFP11 | SPI3 serial clock pin.                                                                     |
|        |        | 61     | PB.10            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        | EADC0_CH10       | A    | MFP1  | EADC0 channel 10 analog input.                                                             |
|        |        |        | EBI_ADR17        | O    | MFP2  | EBI address bus bit 17.                                                                    |
|        |        |        | USCI1_CTL0       | I/O  | MFP4  | USCI1 control 0 pin.                                                                       |
|        |        |        | UART0_nRTS       | O    | MFP5  | UART0 request to Send output pin.                                                          |
|        |        |        | UART4_RXD        | I    | MFP6  | UART4 data receiver input pin.                                                             |
|        |        |        | I2C1_SDA         | I/O  | MFP7  | I2C1 data input/output pin.                                                                |
|        |        |        | BPWM1_CH1        | I/O  | MFP10 | BPWM1 channel 1 output/capture input.                                                      |
|        |        |        | SPI3_SS          | I/O  | MFP11 | SPI3 slave select pin.                                                                     |
|        |        | 62     | PB.9             | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        | EADC0_CH9        | A    | MFP1  | EADC0 channel 9 analog input.                                                              |
|        |        |        | EBI_ADR18        | O    | MFP2  | EBI address bus bit 18.                                                                    |
|        |        |        | USCI1_CTL1       | I/O  | MFP4  | USCI1 control 1 pin.                                                                       |
|        |        |        | UART0_TXD        | O    | MFP5  | UART0 data transmitter output pin.                                                         |
|        |        |        | UART1_nCTS       | I    | MFP6  | UART1 clear to Send input pin.                                                             |
|        |        |        | I2C1_SMBAL       | O    | MFP7  | I2C1 SMBus SMBALTER pin                                                                    |
|        |        |        | BPWM1_CH2        | I/O  | MFP10 | BPWM1 channel 2 output/capture input.                                                      |
|        |        |        | SPI3_MISO        | I/O  | MFP11 | SPI3 MISO (Master In, Slave Out) pin.                                                      |
|        |        | 63     | INT7             | I    | MFP13 | External interrupt 7 input pin.                                                            |
|        |        |        | PB.8             | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        | EADC0_CH8        | A    | MFP1  | EADC0 channel 8 analog input.                                                              |
|        |        |        | EBI_ADR19        | O    | MFP2  | EBI address bus bit 19.                                                                    |

| 32 Pin | 48 Pin | 64 Pin | Pin Name     | Type | MFP   | Description                               |
|--------|--------|--------|--------------|------|-------|-------------------------------------------|
|        |        |        | USCI1_CLK    | I/O  | MFP4  | USCI1 clock pin.                          |
|        |        |        | UART0_RXD    | I    | MFP5  | UART0 data receiver input pin.            |
|        |        |        | UART1_nRTS   | O    | MFP6  | UART1 request to Send output pin.         |
|        |        |        | I2C1_SMBSUS  | O    | MFP7  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|        |        |        | BPWM1_CH3    | I/O  | MFP10 | BPWM1 channel 3 output/capture input.     |
|        |        |        | SPI3_MOSI    | I/O  | MFP11 | SPI3 MOSI (Master Out, Slave In) pin.     |
|        |        |        | INT6         | I    | MFP13 | External interrupt 6 input pin.           |
|        | 47     | 64     | PB.7         | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |        |        | EADC0_CH7    | A    | MFP1  | EADC0 channel 7 analog input.             |
|        |        |        | EBI_nWRL     | O    | MFP2  | EBI low byte write enable output pin.     |
|        |        |        | USCI1_DAT0   | I/O  | MFP4  | USCI1 data 0 pin.                         |
|        |        |        | UART1_TXD    | O    | MFP6  | UART1 data transmitter output pin.        |
|        |        |        | SD1_CMD      | I/O  | MFP7  | SD/SDIO1 command/response pin             |
|        |        |        | EBI_nCS0     | O    | MFP8  | EBI chip select 0 output pin.             |
|        |        |        | BPWM1_CH4    | I/O  | MFP10 | BPWM1 channel 4 output/capture input.     |
|        |        |        | EPWM1_BRAKE0 | I    | MFP11 | EPWM1 Brake 0 input pin.                  |
|        |        |        | EPWM1_CH4    | I/O  | MFP12 | EPWM1 channel 4 output/capture input.     |
|        |        |        | INT5         | I    | MFP13 | External interrupt 5 input pin.           |
|        |        |        | ACMP0_O      | O    | MFP15 | Analog comparator 0 output pin.           |

## 4.2.2 M482 Series Pin Description

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|--------|--------|---------|------------|------|-------|-----------------------------------------------|
| 1      | 1      | 2      | 1       | PB.5       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EADC0_CH5  | A    | MFP1  | EADC0 channel 5 analog input.                 |
|        |        |        |         | ACMP1_N    | A    | MFP1  | Analog comparator 1 negative input pin.       |
|        |        |        |         | EBI_ADR0   | O    | MFP2  | EBI address bus bit 0.                        |
|        |        |        |         | SD0_DAT3   | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|        |        |        |         | SPI1_MISO  | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |        |        |         | I2C0_SCL   | I/O  | MFP6  | I2C0 clock pin.                               |
|        |        |        |         | UART5_TXD  | O    | MFP7  | UART5 data transmitter output pin.            |
|        |        |        |         | USCI1_CTL0 | I/O  | MFP8  | USCI1 control 0 pin.                          |
|        |        |        |         | SC0_CLK    | O    | MFP9  | Smart Card 0 clock pin.                       |
|        |        |        |         | I2S0_BCLK  | O    | MFP10 | I2S0 bit clock output pin.                    |
|        |        |        |         | EPWM0_CH0  | I/O  | MFP11 | EPWM0 channel 0 output/capture input.         |
|        |        |        |         | TM0        | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |        |        |         | INT0       | I    | MFP15 | External interrupt 0 input pin.               |
| 2      | 2      | 3      | 2       | PB.4       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EADC0_CH4  | A    | MFP1  | EADC0 channel 4 analog input.                 |
|        |        |        |         | ACMP1_P1   | A    | MFP1  | Analog comparator 1 positive input 1 pin.     |
|        |        |        |         | EBI_ADR1   | O    | MFP2  | EBI address bus bit 1.                        |
|        |        |        |         | SD0_DAT2   | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|        |        |        |         | SPI1_MOSI  | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |        |        |         | I2C0_SDA   | I/O  | MFP6  | I2C0 data input/output pin.                   |
|        |        |        |         | UART5_RXD  | I    | MFP7  | UART5 data receiver input pin.                |
|        |        |        |         | USCI1_CTL1 | I/O  | MFP8  | USCI1 control 1 pin.                          |
|        |        |        |         | SC0_DAT    | I/O  | MFP9  | Smart Card 0 data pin.                        |
|        |        |        |         | I2S0_MCLK  | O    | MFP10 | I2S0 master clock output pin.                 |
|        |        |        |         | EPWM0_CH1  | I/O  | MFP11 | EPWM0 channel 1 output/capture input.         |
|        |        |        |         | TM1        | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
|        |        |        |         | INT1       | I    | MFP15 | External interrupt 1 input pin.               |
| 3      | 3      | 4      | 3       | PB.3       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EADC0_CH3  | A    | MFP1  | EADC0 channel 3 analog input.                 |
|        |        |        |         | ACMP0_N    | A    | MFP1  | Analog comparator 0 negative input pin.       |
|        |        |        |         | EBI_ADR2   | O    | MFP2  | EBI address bus bit 2.                        |
|        |        |        |         | SD0_DAT1   | I/O  | MFP3  | SD/SDIO0 data line bit 1.                     |

| 32 Pin           | 48 Pin | 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|------------------|--------|--------|---------|------------|------|-------|-----------------------------------------------|
| 4<br>4<br>5<br>4 | 5      | 5      | 4       | SPI1_CLK   | I/O  | MFP5  | SPI1 serial clock pin.                        |
|                  |        |        |         | UART1_TXD  | O    | MFP6  | UART1 data transmitter output pin.            |
|                  |        |        |         | UART5_nRTS | O    | MFP7  | UART5 request to Send output pin.             |
|                  |        |        |         | USCI1_DAT1 | I/O  | MFP8  | USCI1 data 1 pin.                             |
|                  |        |        |         | SC0_RST    | O    | MFP9  | Smart Card 0 reset pin.                       |
|                  |        |        |         | I2S0_DI    | I    | MFP10 | I2S0 data input pin.                          |
|                  |        |        |         | EPWM0_CH2  | I/O  | MFP11 | EPWM0 channel 2 output/capture input.         |
|                  |        |        |         | TM2        | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|                  |        |        |         | INT2       | I    | MFP15 | External interrupt 2 input pin.               |
|                  |        |        |         | PB.2       | I/O  | MFP0  | General purpose digital I/O pin.              |
|                  |        |        |         | EADC0_CH2  | A    | MFP1  | EADC0 channel 2 analog input.                 |
|                  |        |        |         | ACMP0_P1   | A    | MFP1  | Analog comparator 0 positive input 1 pin.     |
|                  |        |        |         | OPA0_O     | A    | MFP1  | Operational amplifier 0 output pin.           |
|                  |        |        |         | EBI_ADR3   | O    | MFP2  | EBI address bus bit 3.                        |
|                  |        |        |         | SD0_DAT0   | I/O  | MFP3  | SD/SDIO0 data line bit 0.                     |
|                  |        |        |         | SPI1_SS    | I/O  | MFP5  | SPI1 slave select pin.                        |
|                  |        |        |         | UART1_RXD  | I    | MFP6  | UART1 data receiver input pin.                |
|                  |        |        |         | UART5_nCTS | I    | MFP7  | UART5 clear to Send input pin.                |
|                  |        |        |         | USCI1_DAT0 | I/O  | MFP8  | USCI1 data 0 pin.                             |
|                  |        |        |         | SC0_PWR    | O    | MFP9  | Smart Card 0 power pin.                       |
|                  |        |        |         | I2S0_DO    | O    | MFP10 | I2S0 data output pin.                         |
|                  |        |        |         | EPWM0_CH3  | I/O  | MFP11 | EPWM0 channel 3 output/capture input.         |
|                  |        |        |         | TM3        | I/O  | MFP14 | Timer3 event counter input/toggle output pin. |
|                  |        |        |         | INT3       | I    | MFP15 | External interrupt 3 input pin.               |
| 5                | 6      | 6      | 6       | PC.12      | I/O  | MFP0  | General purpose digital I/O pin.              |
|                  |        |        |         | EBI_ADR4   | O    | MFP2  | EBI address bus bit 4.                        |
|                  |        |        |         | UART0_TXD  | O    | MFP3  | UART0 data transmitter output pin.            |
|                  |        |        |         | I2C0_SCL   | I/O  | MFP4  | I2C0 clock pin.                               |
|                  |        |        |         | SPI3_MISO  | I/O  | MFP6  | SPI3 MISO (Master In, Slave Out) pin.         |
|                  |        |        |         | SC0_nCD    | I    | MFP9  | Smart Card 0 card detect pin.                 |
|                  |        |        |         | ECAP1_IC2  | I    | MFP11 | Enhanced capture unit 1 input 2 pin.          |
|                  |        |        |         | EPWM1_CH0  | I/O  | MFP12 | EPWM1 channel 0 output/capture input.         |
|                  |        |        |         | ACMP0_O    | O    | MFP14 | Analog comparator 0 output pin.               |
|                  |        |        |         | PC.11      | I/O  | MFP0  | General purpose digital I/O pin.              |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | EBI_ADR5     | O    | MFP2  | EBI address bus bit 5.                      |
|        |        |        |         | UART0_RXD    | I    | MFP3  | UART0 data receiver input pin.              |
|        |        |        |         | I2C0_SDA     | I/O  | MFP4  | I2C0 data input/output pin.                 |
|        |        |        |         | SPI3_MOSI    | I/O  | MFP6  | SPI3 MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | ECAP1_IC1    | I    | MFP11 | Enhanced capture unit 1 input 1 pin.        |
|        |        |        |         | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        |        |        |         | ACMP1_O      | O    | MFP14 | Analog comparator 1 output pin.             |
|        |        |        | 7       | PC.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_ADR6     | O    | MFP2  | EBI address bus bit 6.                      |
|        |        |        |         | SPI3_CLK     | I/O  | MFP6  | SPI3 serial clock pin.                      |
|        |        |        |         | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.          |
|        |        |        |         | CAN1_TXD     | O    | MFP9  | CAN1 bus transmitter output.                |
|        |        |        |         | ECAP1_IC0    | I    | MFP11 | Enhanced capture unit 1 input 0 pin.        |
|        |        |        |         | EPWM1_CH2    | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        |        |        | 8       | PC.9         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_ADR7     | O    | MFP2  | EBI address bus bit 7.                      |
|        |        |        |         | SPI3_SS      | I/O  | MFP6  | SPI3 slave select pin.                      |
|        |        |        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.              |
|        |        |        |         | CAN1_RXD     | I    | MFP9  | CAN1 bus receiver input.                    |
|        |        |        |         | EPWM1_CH3    | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        |        |        | 9       | PB.1         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EADC0_CH1    | A    | MFP1  | EADC0 channel 1 analog input.               |
|        |        |        |         | OPA0_N       | A    | MFP1  | Operational amplifier 0 negative input pin. |
|        |        |        |         | EBI_ADR8     | O    | MFP2  | EBI address bus bit 8.                      |
|        |        |        |         | SD0_CLK      | O    | MFP3  | SD/SDIO0 clock output pin                   |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin            |
|        |        |        |         | SPI3_I2SMCLK | I/O  | MFP6  | SPI3 I2S master clock output pin            |
|        |        |        |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.          |
|        |        |        |         | USCI1_CLK    | I/O  | MFP8  | USCI1 clock pin.                            |
|        |        |        |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |        |        |         | I2S0_LRCK    | O    | MFP10 | I2S0 left right channel clock output pin.   |
|        |        |        |         | EPWM0_CH4    | I/O  | MFP11 | EPWM0 channel 4 output/capture input.       |
|        |        |        |         | EPWM1_CH4    | I/O  | MFP12 | EPWM1 channel 4 output/capture input.       |
|        |        |        |         | EPWM0_BRAKE0 | I    | MFP13 | EPWM0 Brake 0 input pin.                    |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
| 6      | 6      | 7      | 10      | PB.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EADC0_CH0       | A    | MFP1  | EADC0 channel 0 analog input.                                                   |
|        |        |        |         | OPA0_P          | A    | MFP1  | Operational amplifier 0 positive input pin.                                     |
|        |        |        |         | EBI_ADR9        | O    | MFP2  | EBI address bus bit 9.                                                          |
|        |        |        |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                   |
|        |        |        |         | UART2_RXD       | I    | MFP7  | UART2 data receiver input pin.                                                  |
|        |        |        |         | SPI0_I2SMCLK    | I/O  | MFP8  | SPI0 I2S master clock output pin                                                |
|        |        |        |         | I2C1_SDA        | I/O  | MFP9  | I2C1 data input/output pin.                                                     |
|        |        |        |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |        |        |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |        |        |         | EPWM0_BRAKE1    | I    | MFP13 | EPWM0 Brake 1 input pin.                                                        |
|        |        |        | 11      | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        | 12      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 7      | 8      | 13     | 13      | PA.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | ACMP0_P0        | A    | MFP1  | Analog comparator 0 positive input 0 pin.                                       |
|        |        |        |         | EBI_nRD         | O    | MFP2  | EBI read enable output pin.                                                     |
|        |        |        |         | SC2_PWR         | O    | MFP3  | Smart Card 2 power pin.                                                         |
|        |        |        |         | SPI2_SS         | I/O  | MFP4  | SPI2 slave select pin.                                                          |
|        |        |        |         | SD1_DAT3        | I/O  | MFP5  | SD/SDIO1 data line bit 3.                                                       |
|        |        |        |         | USCI0_CLK       | I/O  | MFP6  | USCI0 clock pin.                                                                |
|        |        |        |         | I2C2_SCL        | I/O  | MFP7  | I2C2 clock pin.                                                                 |
|        |        |        |         | BPWM0_CH0       | I/O  | MFP9  | BPWM0 channel 0 output/capture input.                                           |
|        |        |        |         | EPWM0_SYNC_OUT  | O    | MFP10 | EPWM0 counter synchronous trigger output pin.                                   |
|        |        |        |         | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
|        |        |        |         | DAC1_ST         | I    | MFP14 | DAC1 external trigger input.                                                    |
| 8      | 9      | 14     | 14      | PA.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | ACMP1_P0        | A    | MFP1  | Analog comparator 1 positive input 0 pin.                                       |
|        |        |        |         | OPA1_O          | A    | MFP1  | Operational amplifier 1 output pin.                                             |
|        |        |        |         | EBI_nWR         | O    | MFP2  | EBI write enable output pin.                                                    |
|        |        |        |         | SC2_RST         | O    | MFP3  | Smart Card 2 reset pin.                                                         |
|        |        |        |         | SPI2_CLK        | I/O  | MFP4  | SPI2 serial clock pin.                                                          |
|        |        |        |         | SD1_DAT2        | I/O  | MFP5  | SD/SDIO1 data line bit 2.                                                       |
|        |        |        |         | USCI0_DAT0      | I/O  | MFP6  | USCI0 data 0 pin.                                                               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                      |
|--------|--------|--------|---------|------------|------|-------|--------------------------------------------------|
|        |        |        |         | I2C2_SDA   | I/O  | MFP7  | I2C2 data input/output pin.                      |
|        |        |        |         | BPWM0_CH1  | I/O  | MFP9  | BPWM0 channel 1 output/capture input.            |
|        |        |        |         | QEI1_INDEX | I    | MFP10 | Quadrature encoder 1 index input                 |
|        |        |        |         | ECAP0_IC0  | I    | MFP11 | Enhanced capture unit 0 input 0 pin.             |
|        |        |        |         | TM1_EXT    | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |        |        |         | DAC0_ST    | I    | MFP14 | DAC0 external trigger input.                     |
|        | 9      | 10     | 15      | PA.9       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | OPA1_N     | A    | MFP1  | Operational amplifier 1 negative input pin.      |
|        |        |        |         | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.                   |
|        |        |        |         | SC2_DAT    | I/O  | MFP3  | Smart Card 2 data pin.                           |
|        |        |        |         | SPI2_MISO  | I/O  | MFP4  | SPI2 MISO (Master In, Slave Out) pin.            |
|        |        |        |         | SD1_DAT1   | I/O  | MFP5  | SD/SDIO1 data line bit 1.                        |
|        |        |        |         | USCI0_DAT1 | I/O  | MFP6  | USCI0 data 1 pin.                                |
|        |        |        |         | UART1_TXD  | O    | MFP7  | UART1 data transmitter output pin.               |
|        |        |        |         | BPWM0_CH2  | I/O  | MFP9  | BPWM0 channel 2 output/capture input.            |
|        |        |        |         | QEI1_A     | I    | MFP10 | Quadrature encoder 1 phase A input               |
|        |        |        |         | ECAP0_IC1  | I    | MFP11 | Enhanced capture unit 0 input 1 pin.             |
|        |        |        |         | TM2_EXT    | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|        | 10     | 11     | 16      | PA.8       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | OPA1_P     | A    | MFP1  | Operational amplifier 1 positive input pin.      |
|        |        |        |         | EBI_ALE    | O    | MFP2  | EBI address latch enable output pin.             |
|        |        |        |         | SC2_CLK    | O    | MFP3  | Smart Card 2 clock pin.                          |
|        |        |        |         | SPI2_MOSI  | I/O  | MFP4  | SPI2 MOSI (Master Out, Slave In) pin.            |
|        |        |        |         | SD1_DAT0   | I/O  | MFP5  | SD/SDIO1 data line bit 0.                        |
|        |        |        |         | USCI0_CTL1 | I/O  | MFP6  | USCI0 control 1 pin.                             |
|        |        |        |         | UART1_RXD  | I    | MFP7  | UART1 data receiver input pin.                   |
|        |        |        |         | BPWM0_CH3  | I/O  | MFP9  | BPWM0 channel 3 output/capture input.            |
|        |        |        |         | QEI1_B     | I    | MFP10 | Quadrature encoder 1 phase B input               |
|        |        |        |         | ECAP0_IC2  | I    | MFP11 | Enhanced capture unit 0 input 2 pin.             |
|        |        |        |         | TM3_EXT    | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
|        |        |        |         | INT4       | I    | MFP15 | External interrupt 4 input pin.                  |
|        |        |        | 17      | PC.13      | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | EBI_ADR10  | O    | MFP2  | EBI address bus bit 10.                          |
|        |        |        |         | SC2_nCD    | I    | MFP3  | Smart Card 2 card detect pin.                    |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | SPI2_I2SMCLK | I/O  | MFP4  | SPI2 I2S master clock output pin            |
|        |        |        |         | CAN1_TXD     | O    | MFP5  | CAN1 bus transmitter output.                |
|        |        |        |         | USCI0_CTL0   | I/O  | MFP6  | USCI0 control 0 pin.                        |
|        |        |        |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.          |
|        |        |        |         | BPWM0_CH4    | I/O  | MFP9  | BPWM0 channel 4 output/capture input.       |
|        |        |        |         | CLKO         | O    | MFP13 | Clock Out                                   |
|        |        |        |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.               |
|        |        |        | 18      | PD.12        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | OPA2_O       | A    | MFP1  | Operational amplifier 2 output pin.         |
|        |        |        |         | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.               |
|        |        |        |         | CAN1_RXD     | I    | MFP5  | CAN1 bus receiver input.                    |
|        |        |        |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.              |
|        |        |        |         | BPWM0_CH5    | I/O  | MFP9  | BPWM0 channel 5 output/capture input.       |
|        |        |        |         | QEIO_INDEX   | I    | MFP10 | Quadrature encoder 0 index input            |
|        |        |        |         | CLKO         | O    | MFP13 | Clock Out                                   |
|        |        |        |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.               |
|        |        |        |         | INT5         | I    | MFP15 | External interrupt 5 input pin.             |
|        |        |        | 19      | PD.11        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | OPA2_N       | A    | MFP1  | Operational amplifier 2 negative input pin. |
|        |        |        |         | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.               |
|        |        |        |         | UART1_TXD    | O    | MFP3  | UART1 data transmitter output pin.          |
|        |        |        |         | CAN0_RXD     | O    | MFP4  | CAN0 bus transmitter output.                |
|        |        |        |         | QEIO_A       | I    | MFP10 | Quadrature encoder 0 phase A input          |
|        |        |        |         | INT6         | I    | MFP15 | External interrupt 6 input pin.             |
|        |        |        | 20      | PD.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | OPA2_P       | A    | MFP1  | Operational amplifier 2 positive input pin. |
|        |        |        |         | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.               |
|        |        |        |         | UART1_RXD    | I    | MFP3  | UART1 data receiver input pin.              |
|        |        |        |         | CAN0_RXD     | I    | MFP4  | CAN0 bus receiver input.                    |
|        |        |        |         | QEIO_B       | I    | MFP10 | Quadrature encoder 0 phase B input          |
|        |        |        |         | INT7         | I    | MFP15 | External interrupt 7 input pin.             |
|        |        |        | 21      | PG.2         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.                     |
|        |        |        |         | SPI2_SS      | I/O  | MFP3  | SPI2 slave select pin.                      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------|--------|---------|--------------|------|-------|-----------------------------------------------|
|        |        |        |         | I2C0_SMBAL   | O    | MFP4  | I2C0 SMBus SMBALTER pin                       |
|        |        |        |         | I2C1_SCL     | I/O  | MFP5  | I2C1 clock pin.                               |
|        |        |        |         | TM0          | I/O  | MFP13 | Timer0 event counter input/toggle output pin. |
|        |        |        | 22      | PG.3         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.                       |
|        |        |        |         | SPI2_CLK     | I/O  | MFP3  | SPI2 serial clock pin.                        |
|        |        |        |         | I2C0_SMBSUS  | O    | MFP4  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)     |
|        |        |        |         | I2C1_SDA     | I/O  | MFP5  | I2C1 data input/output pin.                   |
|        |        |        |         | TM1          | I/O  | MFP13 | Timer1 event counter input/toggle output pin. |
|        |        |        | 23      | PG.4         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.                       |
|        |        |        |         | SPI2_MISO    | I/O  | MFP3  | SPI2 MISO (Master In, Slave Out) pin.         |
|        |        |        |         | TM2          | I/O  | MFP13 | Timer2 event counter input/toggle output pin. |
|        |        |        | 24      | PF.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.                       |
|        |        |        |         | SPI2_MOSI    | I/O  | MFP3  | SPI2 MOSI (Master Out, Slave In) pin.         |
|        |        |        |         | TAMPER5      | I/O  | MFP10 | TAMPER detector loop pin 5.                   |
|        |        |        |         | TM3          | I/O  | MFP13 | Timer3 event counter input/toggle output pin. |
|        |        |        | 25      | PF.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |        |        |         | SC0_nCD      | I    | MFP3  | Smart Card 0 card detect pin.                 |
|        |        |        |         | I2S0_BCLK    | O    | MFP4  | I2S0 bit clock output pin.                    |
|        |        |        |         | SPI0_I2SMCLK | I/O  | MFP5  | SPI0 I2S master clock output pin              |
|        |        |        |         | TAMPER4      | I/O  | MFP10 | TAMPER detector loop pin 4.                   |
|        |        |        | 26      | PF.9         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |        |        |         | SC0_PWR      | O    | MFP3  | Smart Card 0 power pin.                       |
|        |        |        |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.                 |
|        |        |        |         | SPI0_SS      | I/O  | MFP5  | SPI0 slave select pin.                        |
|        |        |        |         | TAMPER3      | I/O  | MFP10 | TAMPER detector loop pin 3.                   |
|        |        |        | 27      | PF.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR17    | O    | MFP2  | EBI address bus bit 17.                       |
|        |        |        |         | SC0_RST      | O    | MFP3  | Smart Card 0 reset pin.                       |
|        |        |        |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                          |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type           | MFP   | Description                                                                     |                                               |
|--------|--------|--------|---------|-----------------|----------------|-------|---------------------------------------------------------------------------------|-----------------------------------------------|
|        |        |        |         | SPI0_CLK        | I/O            | MFP5  | SPI0 serial clock pin.                                                          |                                               |
|        |        |        |         | TAMPER2         | I/O            | MFP10 | TAMPER detector loop pin 2.                                                     |                                               |
|        |        | 28     |         | PF.7            | I/O            | MFP0  | General purpose digital I/O pin.                                                |                                               |
|        |        |        |         | EBI_ADR18       | O              | MFP2  | EBI address bus bit 18.                                                         |                                               |
|        |        |        |         | SC0_DAT         | I/O            | MFP3  | Smart Card 0 data pin.                                                          |                                               |
|        |        |        |         | I2S0_DO         | O              | MFP4  | I2S0 data output pin.                                                           |                                               |
|        |        |        |         | SPI0_MISO       | I/O            | MFP5  | SPI0 MISO (Master In, Slave Out) pin.                                           |                                               |
|        |        |        |         | UART4_TXD       | O              | MFP6  | UART4 data transmitter output pin.                                              |                                               |
|        |        |        |         | TAMPER1         | I/O            | MFP10 | TAMPER detector loop pin 1.                                                     |                                               |
|        |        | 12     | 29      | PF.6            | I/O            | MFP0  | General purpose digital I/O pin.                                                |                                               |
|        |        |        |         | EBI_ADR19       | O              | MFP2  | EBI address bus bit 19.                                                         |                                               |
|        |        |        |         | SC0_CLK         | O              | MFP3  | Smart Card 0 clock pin.                                                         |                                               |
|        |        |        |         | I2S0_LRCK       | O              | MFP4  | I2S0 left right channel clock output pin.                                       |                                               |
|        |        |        |         | SPI0_MOSI       | I/O            | MFP5  | SPI0 MOSI (Master Out, Slave In) pin.                                           |                                               |
|        |        |        |         | UART4_RXD       | I              | MFP6  | UART4 data receiver input pin.                                                  |                                               |
|        |        |        |         | EBI_nCS0        | O              | MFP7  | EBI chip select 0 output pin.                                                   |                                               |
|        |        |        |         | TAMPER0         | I/O            | MFP10 | TAMPER detector loop pin 0.                                                     |                                               |
|        |        | 13     | 30      | V <sub>DD</sub> | P              | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |                                               |
|        |        | 11     | 14      | 31              | PF.5           | I/O   | MFP0                                                                            | General purpose digital I/O pin.              |
|        |        |        |         |                 | UART2_RXD      | I     | MFP2                                                                            | UART2 data receiver input pin.                |
|        |        |        |         |                 | UART2_nCTS     | I     | MFP4                                                                            | UART2 clear to Send input pin.                |
|        |        |        |         |                 | BPWM0_CH4      | I/O   | MFP8                                                                            | BPWM0 channel 4 output/capture input.         |
|        |        |        |         |                 | EPWM0_SYNC_OUT | O     | MFP9                                                                            | EPWM0 counter synchronous trigger output pin. |
|        |        |        |         |                 | X32_IN         | I     | MFP10                                                                           | External 32.768 kHz crystal input pin.        |
|        |        |        |         |                 | EADC0_ST       | I     | MFP11                                                                           | EADC0 external trigger input.                 |
|        |        | 12     | 15      | 32              | PF.4           | I/O   | MFP0                                                                            | General purpose digital I/O pin.              |
|        |        |        |         |                 | UART2_TXD      | O     | MFP2                                                                            | UART2 data transmitter output pin.            |
|        |        |        |         |                 | UART2_nRTS     | O     | MFP4                                                                            | UART2 request to Send output pin.             |
|        |        |        |         |                 | BPWM0_CH5      | I/O   | MFP8                                                                            | BPWM0 channel 5 output/capture input.         |
|        |        |        |         |                 | X32_OUT        | O     | MFP10                                                                           | External 32.768 kHz crystal output pin.       |
|        |        |        | 33      | PH.4            | I/O            | MFP0  | General purpose digital I/O pin.                                                |                                               |
|        |        |        |         | EBI_ADR3        | O              | MFP2  | EBI address bus bit 3.                                                          |                                               |
|        |        |        |         | SPI1_MISO       | I/O            | MFP3  | SPI1 MISO (Master In, Slave Out) pin.                                           |                                               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        | 34      | PH.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR2        | O    | MFP2  | EBI address bus bit 2.                                                          |
|        |        |        |         | SPI1_MOSI       | I/O  | MFP3  | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|        |        |        | 35      | PH.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR1        | O    | MFP2  | EBI address bus bit 1.                                                          |
|        |        |        |         | SPI1_CLK        | I/O  | MFP3  | SPI1 serial clock pin.                                                          |
|        |        |        | 36      | PH.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR0        | O    | MFP2  | EBI address bus bit 0.                                                          |
|        |        |        |         | SPI1_SS         | I/O  | MFP3  | SPI1 slave select pin.                                                          |
| 9      | 13     | 16     | 37      | PF.3            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_nCS0        | O    | MFP2  | EBI chip select 0 output pin.                                                   |
|        |        |        |         | UART0_TXD       | O    | MFP3  | UART0 data transmitter output pin.                                              |
|        |        |        |         | I2C0_SCL        | I/O  | MFP4  | I2C0 clock pin.                                                                 |
|        |        |        |         | XT1_IN          | I    | MFP10 | External 4~24 MHz (high speed) crystal input pin.                               |
|        |        |        |         | BPWM1_CH0       | I/O  | MFP11 | BPWM1 channel 0 output/capture input.                                           |
| 10     | 14     | 17     | 38      | PF.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_nCS1        | O    | MFP2  | EBI chip select 1 output pin.                                                   |
|        |        |        |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.                                                  |
|        |        |        |         | I2C0_SDA        | I/O  | MFP4  | I2C0 data input/output pin.                                                     |
|        |        |        |         | QSPI0_CLK       | I/O  | MFP5  | Quad SPI0 serial clock pin.                                                     |
|        |        |        |         | XT1_OUT         | O    | MFP10 | External 4~24 MHz (high speed) crystal output pin.                              |
|        |        |        |         | BPWM1_CH1       | I/O  | MFP11 | BPWM1 channel 1 output/capture input.                                           |
|        |        |        | 39      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        |         | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 41      | PE.8            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR10       | O    | MFP2  | EBI address bus bit 10.                                                         |
|        |        |        |         | I2S0_BCLK       | O    | MFP4  | I2S0 bit clock output pin.                                                      |
|        |        |        |         | SPI2_CLK        | I/O  | MFP5  | SPI2 serial clock pin.                                                          |
|        |        |        |         | USCI1_CTL1      | I/O  | MFP6  | USCI1 control 1 pin.                                                            |
|        |        |        |         | UART2_TXD       | O    | MFP7  | UART2 data transmitter output pin.                                              |
|        |        |        |         | EPWM0_CH0       | I/O  | MFP10 | EPWM0 channel 0 output/capture input.                                           |
|        |        |        |         | EPWM0_BRAKE0    | I    | MFP11 | EPWM0 Brake 0 input pin.                                                        |
|        |        |        |         | ECAPO_IC0       | I    | MFP12 | Enhanced capture unit 0 input 0 pin.                                            |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------|
|        |        |        |         | TRACE_CLK    | O    | MFP14 | ETM Trace Clock output pin            |
|        |        |        |         | PE.9         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.               |
|        |        |        |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.         |
|        |        |        |         | SPI2_MISO    | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin. |
|        |        |        |         | USCI1_CTL0   | I/O  | MFP6  | USCI1 control 0 pin.                  |
|        |        |        |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.        |
|        |        |        |         | EPWM0_CH1    | I/O  | MFP10 | EPWM0 channel 1 output/capture input. |
|        |        |        |         | EPWM0_BRAKE1 | I    | MFP11 | EPWM0 Brake 1 input pin.              |
|        |        |        |         | ECAP0_IC1    | I    | MFP12 | Enhanced capture unit 0 input 1 pin.  |
|        |        |        |         | TRACE_DATA0  | O    | MFP14 | ETM Trace Data 0 output pin           |
|        |        |        |         | PE.10        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.               |
|        |        |        |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                  |
|        |        |        |         | SPI2_MOSI    | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin. |
|        |        |        |         | USCI1_DAT0   | I/O  | MFP6  | USCI1 data 0 pin.                     |
|        |        |        |         | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.    |
|        |        |        |         | EPWM0_CH2    | I/O  | MFP10 | EPWM0 channel 2 output/capture input. |
|        |        |        |         | EPWM1_BRAKE0 | I    | MFP11 | EPWM1 Brake 0 input pin.              |
|        |        |        |         | ECAP0_IC2    | I    | MFP12 | Enhanced capture unit 0 input 2 pin.  |
|        |        |        |         | TRACE_DATA1  | O    | MFP14 | ETM Trace Data 1 output pin           |
|        |        |        |         | PE.11        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.               |
|        |        |        |         | I2S0_DO      | O    | MFP4  | I2S0 data output pin.                 |
|        |        |        |         | SPI2_SS      | I/O  | MFP5  | SPI2 slave select pin.                |
|        |        |        |         | USCI1_DAT1   | I/O  | MFP6  | USCI1 data 1 pin.                     |
|        |        |        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.        |
|        |        |        |         | UART1_nCTS   | I    | MFP8  | UART1 clear to Send input pin.        |
|        |        |        |         | EPWM0_CH3    | I/O  | MFP10 | EPWM0 channel 3 output/capture input. |
|        |        |        |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.              |
|        |        |        |         | ECAP1_IC2    | I    | MFP13 | Enhanced capture unit 1 input 2 pin.  |
|        |        |        |         | TRACE_DATA2  | O    | MFP14 | ETM Trace Data 2 output pin           |
|        |        |        |         | PE.12        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------|--------|---------|--------------|------|-------|-----------------------------------------------|
|        |        |        |         | I2S0_LRCK    | O    | MFP4  | I2S0 left right channel clock output pin.     |
|        |        |        |         | SPI2_I2SMCLK | I/O  | MFP5  | SPI2 I2S master clock output pin              |
|        |        |        |         | USCI1_CLK    | I/O  | MFP6  | USCI1 clock pin.                              |
|        |        |        |         | UART1_nRTS   | O    | MFP8  | UART1 request to Send output pin.             |
|        |        |        |         | EPWM0_CH4    | I/O  | MFP10 | EPWM0 channel 4 output/capture input.         |
|        |        |        |         | ECAP1_IC1    | I    | MFP13 | Enhanced capture unit 1 input 1 pin.          |
|        |        |        |         | TRACE_DATA3  | O    | MFP14 | ETM Trace Data 3 output pin                   |
|        |        |        | 46      | PE.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |        |        |         | I2C0_SCL     | I/O  | MFP4  | I2C0 clock pin.                               |
|        |        |        |         | UART4_nRTS   | O    | MFP5  | UART4 request to Send output pin.             |
|        |        |        |         | UART1_TXD    | O    | MFP8  | UART1 data transmitter output pin.            |
|        |        |        |         | EPWM0_CH5    | I/O  | MFP10 | EPWM0 channel 5 output/capture input.         |
|        |        |        |         | EPWM1_CH0    | I/O  | MFP11 | EPWM1 channel 0 output/capture input.         |
|        |        |        |         | BPWM1_CH5    | I/O  | MFP12 | BPWM1 channel 5 output/capture input.         |
|        |        |        |         | ECAP1_IC0    | I    | MFP13 | Enhanced capture unit 1 input 0 pin.          |
|        |        |        | 47      | PC.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |        |        |         | I2C0_SDA     | I/O  | MFP4  | I2C0 data input/output pin.                   |
|        |        |        |         | UART4_nCTS   | I    | MFP5  | UART4 clear to Send input pin.                |
|        |        |        |         | UART1_RXD    | I    | MFP8  | UART1 data receiver input pin.                |
|        |        |        |         | EPWM1_CH1    | I/O  | MFP11 | EPWM1 channel 1 output/capture input.         |
|        |        |        |         | BPWM1_CH4    | I/O  | MFP12 | BPWM1 channel 4 output/capture input.         |
|        |        | 48     | 18      | PC.7         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_AD9      | I/O  | MFP2  | EBI address/data bus bit 9.                   |
|        |        |        |         | SPI1_MISO    | I/O  | MFP4  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |        |        |         | UART4_TXD    | O    | MFP5  | UART4 data transmitter output pin.            |
|        |        |        |         | SC2_PWR      | O    | MFP6  | Smart Card 2 power pin.                       |
|        |        |        |         | UART0_nCTS   | I    | MFP7  | UART0 clear to Send input pin.                |
|        |        |        |         | I2C1_SMBAL   | O    | MFP8  | I2C1 SMBus SMBALTER pin                       |
|        |        |        |         | EPWM1_CH2    | I/O  | MFP11 | EPWM1 channel 2 output/capture input.         |
|        |        |        |         | BPWM1_CH0    | I/O  | MFP12 | BPWM1 channel 0 output/capture input.         |
|        |        |        |         | TM0          | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |        |        |         | INT3         | I    | MFP15 | External interrupt 3 input pin.               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type       | MFP   | Description                                   |                                               |
|--------|--------|--------|---------|-------------|------------|-------|-----------------------------------------------|-----------------------------------------------|
|        |        | 19     | 49      | PC.6        | I/O        | MFP0  | General purpose digital I/O pin.              |                                               |
|        |        |        |         | EBI_AD8     | I/O        | MFP2  | EBI address/data bus bit 8.                   |                                               |
|        |        |        |         | SPI1_MOSI   | I/O        | MFP4  | SPI1 MOSI (Master Out, Slave In) pin.         |                                               |
|        |        |        |         | UART4_RXD   | I          | MFP5  | UART4 data receiver input pin.                |                                               |
|        |        |        |         | SC2_RST     | O          | MFP6  | Smart Card 2 reset pin.                       |                                               |
|        |        |        |         | UART0_nRTS  | O          | MFP7  | UART0 request to Send output pin.             |                                               |
|        |        |        |         | I2C1_SMBSUS | O          | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)     |                                               |
|        |        |        |         | EPWM1_CH3   | I/O        | MFP11 | EPWM1 channel 3 output/capture input.         |                                               |
|        |        |        |         | BPWM1_CH1   | I/O        | MFP12 | BPWM1 channel 1 output/capture input.         |                                               |
|        |        |        |         | TM1         | I/O        | MFP14 | Timer1 event counter input/toggle output pin. |                                               |
|        |        | 15     | 20      | 50          | PA.7       | I/O   | MFP0                                          | General purpose digital I/O pin.              |
|        |        |        |         |             | EBI_AD7    | I/O   | MFP2                                          | EBI address/data bus bit 7.                   |
|        |        |        |         |             | SPI1_CLK   | I/O   | MFP4                                          | SPI1 serial clock pin.                        |
|        |        |        |         |             | SC2_DAT    | I/O   | MFP6                                          | Smart Card 2 data pin.                        |
|        |        |        |         |             | UART0_TXD  | O     | MFP7                                          | UART0 data transmitter output pin.            |
|        |        |        |         |             | I2C1_SCL   | I/O   | MFP8                                          | I2C1 clock pin.                               |
|        |        |        |         |             | EPWM1_CH4  | I/O   | MFP11                                         | EPWM1 channel 4 output/capture input.         |
|        |        |        |         |             | BPWM1_CH2  | I/O   | MFP12                                         | BPWM1 channel 2 output/capture input.         |
|        |        |        |         |             | ACMP0_WLAT | I     | MFP13                                         | Analog comparator 0 window latch input pin    |
|        |        |        |         |             | TM2        | I/O   | MFP14                                         | Timer2 event counter input/toggle output pin. |
|        |        | 16     | 21      | 51          | PA.6       | I/O   | MFP0                                          | General purpose digital I/O pin.              |
|        |        |        |         |             | EBI_AD6    | I/O   | MFP2                                          | EBI address/data bus bit 6.                   |
|        |        |        |         |             | SPI1_SS    | I/O   | MFP4                                          | SPI1 slave select pin.                        |
|        |        |        |         |             | SD1_nCD    | I     | MFP5                                          | SD/SDIO1 card detect input pin                |
|        |        |        |         |             | SC2_CLK    | O     | MFP6                                          | Smart Card 2 clock pin.                       |
|        |        |        |         |             | UART0_RXD  | I     | MFP7                                          | UART0 data receiver input pin.                |
|        |        |        |         |             | I2C1_SDA   | I/O   | MFP8                                          | I2C1 data input/output pin.                   |
|        |        |        |         |             | EPWM1_CH5  | I/O   | MFP11                                         | EPWM1 channel 5 output/capture input.         |
|        |        |        |         |             | BPWM1_CH3  | I/O   | MFP12                                         | BPWM1 channel 3 output/capture input.         |
|        |        |        |         |             | ACMP1_WLAT | I     | MFP13                                         | Analog comparator 1 window latch input pin    |
|        |        |        |         |             | TM3        | I/O   | MFP14                                         | Timer3 event counter input/toggle output pin. |
|        |        |        |         |             | INT0       | I     | MFP15                                         | External interrupt 0 input pin.               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin      | Pin Name        | Type  | MFP                                         | Description                                                                     |
|--------|--------|--------|--------------|-----------------|-------|---------------------------------------------|---------------------------------------------------------------------------------|
|        |        | 22     | 52           | V <sub>SS</sub> | P     | MFP0                                        | Ground pin for digital circuit.                                                 |
|        |        | 23     | 53           | V <sub>DD</sub> | P     | MFP0                                        | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        | 24     | 54           | LDO_CAP         | A     | MFP0                                        | LDO output pin.                                                                 |
| 17     | 25     | 55     | PA.5         | I/O             | MFP0  | General purpose digital I/O pin.            |                                                                                 |
|        |        |        | SPIM_D2      | I/O             | MFP2  | SPIM data 2 pin for Quad Mode I/O.          |                                                                                 |
|        |        |        | QSPI0_MISO1  | I/O             | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |                                                                                 |
|        |        |        | SPI1_I2SMCLK | I/O             | MFP4  | SPI1 I2S master clock output pin            |                                                                                 |
|        |        |        | SD1_CMD      | I/O             | MFP5  | SD/SDIO1 command/response pin               |                                                                                 |
|        |        |        | SC2_nCD      | I               | MFP6  | Smart Card 2 card detect pin.               |                                                                                 |
|        |        |        | UART0_nCTS   | I               | MFP7  | UART0 clear to Send input pin.              |                                                                                 |
|        |        |        | UART5_TXD    | O               | MFP8  | UART5 data transmitter output pin.          |                                                                                 |
|        |        |        | I2C0_SCL     | I/O             | MFP9  | I2C0 clock pin.                             |                                                                                 |
|        |        |        | CAN0_TXD     | O               | MFP10 | CAN0 bus transmitter output.                |                                                                                 |
|        |        |        | BPWM0_CH5    | I/O             | MFP12 | BPWM0 channel 5 output/capture input.       |                                                                                 |
|        |        |        | EPWM0_CH0    | I/O             | MFP13 | EPWM0 channel 0 output/capture input.       |                                                                                 |
| 18     | 26     | 56     | PA.4         | I/O             | MFP0  | General purpose digital I/O pin.            |                                                                                 |
|        |        |        | SPIM_D3      | I/O             | MFP2  | SPIM data 3 pin for Quad Mode I/O.          |                                                                                 |
|        |        |        | QSPI0_MOSI1  | I/O             | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |                                                                                 |
|        |        |        | SPI0_I2SMCLK | I/O             | MFP4  | SPI0 I2S master clock output pin            |                                                                                 |
|        |        |        | SD1_CLK      | O               | MFP5  | SD/SDIO1 clock output pin                   |                                                                                 |
|        |        |        | SC0_nCD      | I               | MFP6  | Smart Card 0 card detect pin.               |                                                                                 |
|        |        |        | UART0_nRTS   | O               | MFP7  | UART0 request to Send output pin.           |                                                                                 |
|        |        |        | UART5_RXD    | I               | MFP8  | UART5 data receiver input pin.              |                                                                                 |
|        |        |        | I2C0_SDA     | I/O             | MFP9  | I2C0 data input/output pin.                 |                                                                                 |
|        |        |        | CAN0_RXD     | I               | MFP10 | CAN0 bus receiver input.                    |                                                                                 |
|        |        |        | BPWM0_CH4    | I/O             | MFP12 | BPWM0 channel 4 output/capture input.       |                                                                                 |
|        |        |        | EPWM0_CH1    | I/O             | MFP13 | EPWM0 channel 1 output/capture input.       |                                                                                 |
| 11     | 19     | 27     | 57           | PA.3            | I/O   | MFP0                                        | General purpose digital I/O pin.                                                |
|        |        |        |              | SPIM_SS         | I/O   | MFP2                                        | SPIM slave select pin.                                                          |
|        |        |        |              | QSPI0_SS        | I/O   | MFP3                                        | Quad SPI0 slave select pin.                                                     |
|        |        |        |              | SPI0_SS         | I/O   | MFP4                                        | SPI0 slave select pin.                                                          |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------|--------|---------|-------------|------|-------|---------------------------------------------|
|        |        |        |         | SD1_DAT3    | I/O  | MFP5  | SD/SDIO1 data line bit 3.                   |
|        |        |        |         | SC0_PWR     | O    | MFP6  | Smart Card 0 power pin.                     |
|        |        |        |         | UART4_TXD   | O    | MFP7  | UART4 data transmitter output pin.          |
|        |        |        |         | UART1_TXD   | O    | MFP8  | UART1 data transmitter output pin.          |
|        |        |        |         | I2C1_SCL    | I/O  | MFP9  | I2C1 clock pin.                             |
|        |        |        |         | BPWM0_CH3   | I/O  | MFP12 | BPWM0 channel 3 output/capture input.       |
|        |        |        |         | EPWM0_CH2   | I/O  | MFP13 | EPWM0 channel 2 output/capture input.       |
|        |        |        |         | QEI0_B      | I    | MFP14 | Quadrature encoder 0 phase B input          |
| 12     | 20     | 28     | 58      | PA.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | SPIM_CLK    | I/O  | MFP2  | SPIM serial clock pin.                      |
|        |        |        |         | QSPI0_CLK   | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |        |        |         | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                      |
|        |        |        |         | SD1_DAT2    | I/O  | MFP5  | SD/SDIO1 data line bit 2.                   |
|        |        |        |         | SC0_RST     | O    | MFP6  | Smart Card 0 reset pin.                     |
|        |        |        |         | UART4_RXD   | I    | MFP7  | UART4 data receiver input pin.              |
|        |        |        |         | UART1_RXD   | I    | MFP8  | UART1 data receiver input pin.              |
|        |        |        |         | I2C1_SDA    | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |        |        |         | BPWM0_CH2   | I/O  | MFP12 | BPWM0 channel 2 output/capture input.       |
|        |        |        |         | EPWM0_CH3   | I/O  | MFP13 | EPWM0 channel 3 output/capture input.       |
| 13     | 21     | 29     | 59      | PA.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | SPIM_MISO   | I/O  | MFP2  | SPIM MISO (Master In, Slave Out) pin.       |
|        |        |        |         | QSPI0_MISO0 | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |        |        |         | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|        |        |        |         | SD1_DAT1    | I/O  | MFP5  | SD/SDIO1 data line bit 1.                   |
|        |        |        |         | SC0_DAT     | I/O  | MFP6  | Smart Card 0 data pin.                      |
|        |        |        |         | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.          |
|        |        |        |         | UART1_nCTS  | I    | MFP8  | UART1 clear to Send input pin.              |
|        |        |        |         | I2C2_SCL    | I/O  | MFP9  | I2C2 clock pin.                             |
|        |        |        |         | BPWM0_CH1   | I/O  | MFP12 | BPWM0 channel 1 output/capture input.       |
|        |        |        |         | EPWM0_CH4   | I/O  | MFP13 | EPWM0 channel 4 output/capture input.       |
|        |        |        |         | DAC1_ST     | I    | MFP15 | DAC1 external trigger input.                |
| 14     | 22     | 30     | 60      | PA.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | SPIM_MOSI   | I/O  | MFP2  | SPIM MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | QSPI0_MOSI0 | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name          | Type | MFP   | Description                                                                                          |
|--------|--------|--------|---------|-------------------|------|-------|------------------------------------------------------------------------------------------------------|
|        |        |        |         | SPI0_MOSI         | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.                                                                |
|        |        |        |         | SD1_DAT0          | I/O  | MFP5  | SD/SDIO1 data line bit 0.                                                                            |
|        |        |        |         | SC0_CLK           | O    | MFP6  | Smart Card 0 clock pin.                                                                              |
|        |        |        |         | UART0_RXD         | I    | MFP7  | UART0 data receiver input pin.                                                                       |
|        |        |        |         | UART1_nRTS        | O    | MFP8  | UART1 request to Send output pin.                                                                    |
|        |        |        |         | I2C2_SDA          | I/O  | MFP9  | I2C2 data input/output pin.                                                                          |
|        |        |        |         | BPWM0_CH0         | I/O  | MFP12 | BPWM0 channel 0 output/capture input.                                                                |
|        |        |        |         | EPWM0_CH5         | I/O  | MFP13 | EPWM0 channel 5 output/capture input.                                                                |
|        |        |        |         | DAC0_ST           | I    | MFP15 | DAC0 external trigger input.                                                                         |
| 15     | 23     | 31     | 61      | V <sub>DDIO</sub> | P    | MFP0  | Power supply for PA.0~PA.5.                                                                          |
|        |        |        | 62      | PE.14             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | EBI_AD8           | I/O  | MFP2  | EBI address/data bus bit 8.                                                                          |
|        |        |        |         | UART2_TXD         | O    | MFP3  | UART2 data transmitter output pin.                                                                   |
|        |        |        |         | CAN0_TXD          | O    | MFP4  | CAN0 bus transmitter output.                                                                         |
|        |        |        |         | SD1_nCD           | I    | MFP5  | SD/SDIO1 card detect input pin                                                                       |
|        |        |        | 63      | PE.15             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | EBI_AD9           | I/O  | MFP2  | EBI address/data bus bit 9.                                                                          |
|        |        |        |         | UART2_RXD         | I    | MFP3  | UART2 data receiver input pin.                                                                       |
|        |        |        |         | CAN0_RXD          | I    | MFP4  | CAN0 bus receiver input.                                                                             |
| 16     | 24     | 32     | 64      | nRESET            | I    | MFP0  | External reset input: active LOW, with an internal pull-up. Set this pin low reset to initial state. |
|        |        |        | 65      | PF.0              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | UART1_TXD         | O    | MFP2  | UART1 data transmitter output pin.                                                                   |
|        |        |        |         | I2C1_SCL          | I/O  | MFP3  | I2C1 clock pin.                                                                                      |
|        |        |        |         | BPWM1_CH0         | I/O  | MFP12 | BPWM1 channel 0 output/capture input.                                                                |
|        |        |        |         | ICE_DAT           | O    | MFP14 | Serial wired debugger data pin.                                                                      |
|        |        |        | 66      | PF.1              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | UART1_RXD         | I    | MFP2  | UART1 data receiver input pin.                                                                       |
|        |        |        |         | I2C1_SDA          | I/O  | MFP3  | I2C1 data input/output pin.                                                                          |
|        |        |        |         | BPWM1_CH1         | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                                                                |
|        |        |        |         | ICE_CLK           | I    | MFP14 | Serial wired debugger clock pin.                                                                     |
|        |        |        | 67      | PD.9              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | EBI_AD7           | I/O  | MFP2  | EBI address/data bus bit 7.                                                                          |
|        |        |        |         | I2C2_SCL          | I/O  | MFP3  | I2C2 clock pin.                                                                                      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | UART2_nCTS   | I    | MFP4  | UART2 clear to Send input pin.              |
|        |        | 68     |         | PD.8         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD6      | I/O  | MFP2  | EBI address/data bus bit 6.                 |
|        |        |        |         | I2C2_SDA     | I/O  | MFP3  | I2C2 data input/output pin.                 |
|        |        |        |         | UART2_nRTS   | O    | MFP4  | UART2 request to Send output pin.           |
|        | 27     | 35     | 69      | PC.5         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD5      | I/O  | MFP2  | EBI address/data bus bit 5.                 |
|        |        |        |         | SPIM_D2      | I/O  | MFP3  | SPIM data 2 pin for Quad Mode I/O.          |
|        |        |        |         | QSPI0_MISO1  | I/O  | MFP4  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |        |        |         | UART2_TXD    | O    | MFP8  | UART2 data transmitter output pin.          |
|        |        |        |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |        |        |         | CAN0_TXD     | O    | MFP10 | CAN0 bus transmitter output.                |
|        |        |        |         | UART4_TXD    | O    | MFP11 | UART4 data transmitter output pin.          |
|        |        |        |         | EPWM1_CH0    | I/O  | MFP12 | EPWM1 channel 0 output/capture input.       |
|        |        |        |         | PC.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        | 28     | 36     | 70      | EBI_AD4      | I/O  | MFP2  | EBI address/data bus bit 4.                 |
|        |        |        |         | SPIM_D3      | I/O  | MFP3  | SPIM data 3 pin for Quad Mode I/O.          |
|        |        |        |         | QSPI0_MOSI1  | I/O  | MFP4  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |        |        |         | SC1_nCD      | I    | MFP5  | Smart Card 1 card detect pin.               |
|        |        |        |         | I2S0_BCLK    | O    | MFP6  | I2S0 bit clock output pin.                  |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP7  | SPI1 I2S master clock output pin            |
|        |        |        |         | UART2_RXD    | I    | MFP8  | UART2 data receiver input pin.              |
|        |        |        |         | I2C1_SDA     | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |        |        |         | CAN0_RXD     | I    | MFP10 | CAN0 bus receiver input.                    |
|        |        |        |         | UART4_RXD    | I    | MFP11 | UART4 data receiver input pin.              |
|        |        |        |         | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        | 29     | 37     | 71      | PC.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD3      | I/O  | MFP2  | EBI address/data bus bit 3.                 |
|        |        |        |         | SPIM_SS      | I/O  | MFP3  | SPIM slave select pin.                      |
|        |        |        |         | QSPI0_SS     | I/O  | MFP4  | Quad SPI0 slave select pin.                 |
|        |        |        |         | SC1_PWR      | O    | MFP5  | Smart Card 1 power pin.                     |
|        |        |        |         | I2S0_MCLK    | O    | MFP6  | I2S0 master clock output pin.               |
|        |        |        |         | SPI1_MISO    | I/O  | MFP7  | SPI1 MISO (Master In, Slave Out) pin.       |
|        |        |        |         | UART2_nRTS   | O    | MFP8  | UART2 request to Send output pin.           |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------|--------|---------|-------------|------|-------|---------------------------------------------|
|        |        |        |         | I2C0_SMBAL  | O    | MFP9  | I2C0 SMBus SMBALTER pin                     |
|        |        |        |         | CAN1_TXD    | O    | MFP10 | CAN1 bus transmitter output.                |
|        |        |        |         | UART3_TXD   | O    | MFP11 | UART3 data transmitter output pin.          |
|        |        |        |         | EPWM1_CH2   | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        |        |        |         | PC.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD2     | I/O  | MFP2  | EBI address/data bus bit 2.                 |
|        |        |        |         | SPIM_CLK    | I/O  | MFP3  | SPIM serial clock pin.                      |
|        |        |        |         | QSPI0_CLK   | I/O  | MFP4  | Quad SPI0 serial clock pin.                 |
|        |        |        |         | SC1_RST     | O    | MFP5  | Smart Card 1 reset pin.                     |
|        |        |        |         | I2S0_DI     | I    | MFP6  | I2S0 data input pin.                        |
|        |        |        |         | SPI1_MOSI   | I/O  | MFP7  | SPI1 MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | UART2_nCTS  | I    | MFP8  | UART2 clear to Send input pin.              |
|        |        |        |         | I2C0_SMBSUS | O    | MFP9  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |        |        |         | CAN1_RXD    | I    | MFP10 | CAN1 bus receiver input.                    |
|        |        |        |         | UART3_RXD   | I    | MFP11 | UART3 data receiver input pin.              |
|        |        |        |         | EPWM1_CH3   | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        |        |        |         | PC.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD1     | I/O  | MFP2  | EBI address/data bus bit 1.                 |
|        |        |        |         | SPIM_MISO   | I/O  | MFP3  | SPIM MISO (Master In, Slave Out) pin.       |
|        |        |        |         | QSPI0_MISO0 | I/O  | MFP4  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |        |        |         | SC1_DAT     | I/O  | MFP5  | Smart Card 1 data pin.                      |
|        |        |        |         | I2S0_DO     | O    | MFP6  | I2S0 data output pin.                       |
|        |        |        |         | SPI1_CLK    | I/O  | MFP7  | SPI1 serial clock pin.                      |
|        |        |        |         | UART2_TXD   | O    | MFP8  | UART2 data transmitter output pin.          |
|        |        |        |         | I2C0_SCL    | I/O  | MFP9  | I2C0 clock pin.                             |
|        |        |        |         | EPWM1_CH4   | I/O  | MFP12 | EPWM1 channel 4 output/capture input.       |
|        |        |        |         | ACMP0_O     | O    | MFP14 | Analog comparator 0 output pin.             |
|        |        |        |         | PC.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD0     | I/O  | MFP2  | EBI address/data bus bit 0.                 |
|        |        |        |         | SPIM_MOSI   | I/O  | MFP3  | SPIM MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | QSPI0_MOSI0 | I/O  | MFP4  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|        |        |        |         | SC1_CLK     | O    | MFP5  | Smart Card 1 clock pin.                     |
|        |        |        |         | I2S0_LRCK   | O    | MFP6  | I2S0 left right channel clock output pin.   |
|        |        |        |         | SPI1_SS     | I/O  | MFP7  | SPI1 slave select pin.                      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        |         | UART2_RXD       | I    | MFP8  | UART2 data receiver input pin.                                                  |
|        |        |        |         | I2C0_SDA        | I/O  | MFP9  | I2C0 data input/output pin.                                                     |
|        |        |        |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |        |        |         | ACMP1_O         | O    | MFP14 | Analog comparator 1 output pin.                                                 |
|        |        |        | 75      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        | 76      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 77      | PG.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD0         | I/O  | MFP2  | EBI address/data bus bit 0.                                                     |
|        |        |        |         | SD1_DAT3        | I/O  | MFP3  | SD/SDIO1 data line bit 3.                                                       |
|        |        |        |         | SPI_M_D2        | I/O  | MFP4  | SPI_M data 2 pin for Quad Mode I/O.                                             |
|        |        |        |         | BPWM0_CH5       | I/O  | MFP12 | BPWM0 channel 5 output/capture input.                                           |
|        |        |        | 78      | PG.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD1         | I/O  | MFP2  | EBI address/data bus bit 1.                                                     |
|        |        |        |         | SD1_DAT2        | I/O  | MFP3  | SD/SDIO1 data line bit 2.                                                       |
|        |        |        |         | SPI_M_D3        | I/O  | MFP4  | SPI_M data 3 pin for Quad Mode I/O.                                             |
|        |        |        |         | BPWM0_CH4       | I/O  | MFP12 | BPWM0 channel 4 output/capture input.                                           |
|        |        |        | 79      | PG.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD2         | I/O  | MFP2  | EBI address/data bus bit 2.                                                     |
|        |        |        |         | SD1_DAT1        | I/O  | MFP3  | SD/SDIO1 data line bit 1.                                                       |
|        |        |        |         | SPI_M_SS        | I/O  | MFP4  | SPI_M slave select pin.                                                         |
|        |        |        |         | BPWM0_CH3       | I/O  | MFP12 | BPWM0 channel 3 output/capture input.                                           |
|        |        |        | 80      | PG.12           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD3         | I/O  | MFP2  | EBI address/data bus bit 3.                                                     |
|        |        |        |         | SD1_DAT0        | I/O  | MFP3  | SD/SDIO1 data line bit 0.                                                       |
|        |        |        |         | SPI_M_CLK       | I/O  | MFP4  | SPI_M serial clock pin.                                                         |
|        |        |        |         | BPWM0_CH2       | I/O  | MFP12 | BPWM0 channel 2 output/capture input.                                           |
|        |        |        | 81      | PG.13           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD4         | I/O  | MFP2  | EBI address/data bus bit 4.                                                     |
|        |        |        |         | SD1_CMD         | I/O  | MFP3  | SD/SDIO1 command/response pin                                                   |
|        |        |        |         | SPI_M_MISO      | I/O  | MFP4  | SPI_M MISO (Master In, Slave Out) pin.                                          |
|        |        |        |         | BPWM0_CH1       | I/O  | MFP12 | BPWM0 channel 1 output/capture input.                                           |
|        |        |        | 82      | PG.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD5         | I/O  | MFP2  | EBI address/data bus bit 5.                                                     |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                           |
|--------|--------|--------|---------|------------|------|-------|---------------------------------------|
|        |        |        |         | SD1_CLK    | O    | MFP3  | SD/SDIO1 clock output pin             |
|        |        |        |         | SPI_MOSI   | I/O  | MFP4  | SPI MOSI (Master Out, Slave In) pin.  |
|        |        |        |         | BPWM0_CH0  | I/O  | MFP12 | BPWM0 channel 0 output/capture input. |
|        |        | 83     |         | PG.15      | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | SD1_nCD    | I    | MFP3  | SD/SDIO1 card detect input pin        |
|        |        |        |         | CLKO       | O    | MFP14 | Clock Out                             |
|        |        |        |         | EADC0_ST   | I    | MFP15 | EADC0 external trigger input.         |
|        |        | 41     |         | PD.3       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_AD10   | I/O  | MFP2  | EBI address/data bus bit 10.          |
|        |        |        |         | USCI0_CTL1 | I/O  | MFP3  | USCI0 control 1 pin.                  |
|        |        |        |         | SPI0_SS    | I/O  | MFP4  | SPI0 slave select pin.                |
|        |        |        |         | UART3_nRTS | O    | MFP5  | UART3 request to Send output pin.     |
|        |        |        |         | USCI1_CTL0 | I/O  | MFP6  | USCI1 control 0 pin.                  |
|        |        |        |         | SC2_PWR    | O    | MFP7  | Smart Card 2 power pin.               |
|        |        |        |         | SC1_nCD    | I    | MFP8  | Smart Card 1 card detect pin.         |
|        |        |        |         | UART0_TXD  | O    | MFP9  | UART0 data transmitter output pin.    |
|        |        | 42     |         | PD.2       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_AD11   | I/O  | MFP2  | EBI address/data bus bit 11.          |
|        |        |        |         | USCI0_DAT1 | I/O  | MFP3  | USCI0 data 1 pin.                     |
|        |        |        |         | SPI0_CLK   | I/O  | MFP4  | SPI0 serial clock pin.                |
|        |        |        |         | UART3_nCTS | I    | MFP5  | UART3 clear to Send input pin.        |
|        |        |        |         | SC2_RST    | O    | MFP7  | Smart Card 2 reset pin.               |
|        |        |        |         | UART0_RXD  | I    | MFP9  | UART0 data receiver input pin.        |
|        |        | 43     |         | PD.1       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_AD12   | I/O  | MFP2  | EBI address/data bus bit 12.          |
|        |        |        |         | USCI0_DAT0 | I/O  | MFP3  | USCI0 data 0 pin.                     |
|        |        |        |         | SPI0_MISO  | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin. |
|        |        |        |         | UART3_TXD  | O    | MFP5  | UART3 data transmitter output pin.    |
|        |        |        |         | I2C2_SCL   | I/O  | MFP6  | I2C2 clock pin.                       |
|        |        |        |         | SC2_DAT    | I/O  | MFP7  | Smart Card 2 data pin.                |
|        |        | 44     |         | PD.0       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_AD13   | I/O  | MFP2  | EBI address/data bus bit 13.          |
|        |        |        |         | USCI0_CLK  | I/O  | MFP3  | USCI0 clock pin.                      |
|        |        |        |         | SPI0_MOSI  | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin. |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------|--------|---------|--------------|------|-------|-----------------------------------------------|
|        |        |        |         | UART3_RXD    | I    | MFP5  | UART3 data receiver input pin.                |
|        |        |        |         | I2C2_SDA     | I/O  | MFP6  | I2C2 data input/output pin.                   |
|        |        |        |         | SC2_CLK      | O    | MFP7  | Smart Card 2 clock pin.                       |
|        |        |        |         | TM2          | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|        |        |        | 84      | PD.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_AD10     | I/O  | MFP2  | EBI address/data bus bit 10.                  |
|        |        |        |         | SD0_nCD      | I    | MFP3  | SD/SDIO0 card detect input pin                |
|        |        |        |         | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin              |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin              |
|        |        |        |         | SC2_nCD      | I    | MFP7  | Smart Card 2 card detect pin.                 |
|        |        |        |         | PA.12        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | I2S0_BCLK    | O    | MFP2  | I2S0 bit clock output pin.                    |
|        |        |        |         | UART4_TXD    | O    | MFP3  | UART4 data transmitter output pin.            |
|        |        |        | 85      | I2C1_SCL     | I/O  | MFP4  | I2C1 clock pin.                               |
|        |        |        |         | SPI2_SS      | I/O  | MFP5  | SPI2 slave select pin.                        |
|        |        |        |         | CAN0_TXD     | O    | MFP6  | CAN0 bus transmitter output.                  |
|        |        |        |         | SC2_PWR      | O    | MFP7  | Smart Card 2 power pin.                       |
|        |        |        |         | BPWM1_CH2    | I/O  | MFP11 | BPWM1 channel 2 output/capture input.         |
|        |        |        |         | QEI1_INDEX   | I    | MFP12 | Quadrature encoder 1 index input              |
|        |        |        |         | USB_VBUS     | P    | MFP14 | Power supply from USB host or HUB.            |
|        |        |        |         | PA.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | I2S0_MCLK    | O    | MFP2  | I2S0 master clock output pin.                 |
|        |        |        |         | UART4_RXD    | I    | MFP3  | UART4 data receiver input pin.                |
|        |        |        | 86      | I2C1_SDA     | I/O  | MFP4  | I2C1 data input/output pin.                   |
|        |        |        |         | SPI2_CLK     | I/O  | MFP5  | SPI2 serial clock pin.                        |
|        |        |        |         | CAN0_RXD     | I    | MFP6  | CAN0 bus receiver input.                      |
|        |        |        |         | SC2_RST      | O    | MFP7  | Smart Card 2 reset pin.                       |
|        |        |        |         | BPWM1_CH3    | I/O  | MFP11 | BPWM1 channel 3 output/capture input.         |
|        |        |        |         | QEI1_A       | I    | MFP12 | Quadrature encoder 1 phase A input            |
|        |        |        |         | USB_D-       | A    | MFP14 | USB differential signal D-.                   |
|        |        |        |         | PA.14        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | I2S0_DI      | I    | MFP2  | I2S0 data input pin.                          |
|        |        |        |         | UART0_TXD    | O    | MFP3  | UART0 data transmitter output pin.            |
|        |        |        | 87      | SPI2_MISO    | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.         |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        |         | I2C2_SCL        | I/O  | MFP6  | I2C2 clock pin.                                                                 |
|        |        |        |         | SC2_DAT         | I/O  | MFP7  | Smart Card 2 data pin.                                                          |
|        |        |        |         | BPWM1_CH4       | I/O  | MFP11 | BPWM1 channel 4 output/capture input.                                           |
|        |        |        |         | QEI1_B          | I    | MFP12 | Quadrature encoder 1 phase B input                                              |
|        |        |        |         | USB_D+          | A    | MFP14 | USB differential signal D+.                                                     |
| 24     | 36     | 48     | 88      | PA.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | I2S0_DO         | O    | MFP2  | I2S0 data output pin.                                                           |
|        |        |        |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.                                                  |
|        |        |        |         | SPI2_MOSI       | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.                                           |
|        |        |        |         | I2C2_SDA        | I/O  | MFP6  | I2C2 data input/output pin.                                                     |
|        |        |        |         | SC2_CLK         | O    | MFP7  | Smart Card 2 clock pin.                                                         |
|        |        |        |         | BPWM1_CH5       | I/O  | MFP11 | BPWM1 channel 5 output/capture input.                                           |
|        |        |        |         | EPWM0_SYNC_IN   | I    | MFP12 | EPWM0 counter synchronous trigger input pin.                                    |
|        |        |        |         | USB_OTG_ID      | I    | MFP14 | USB_ identification.                                                            |
|        |        |        | 89      | NC              |      |       |                                                                                 |
|        |        |        | 90      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 91      | NC              |      |       |                                                                                 |
|        |        |        | 92      | NC              |      |       |                                                                                 |
|        |        |        | 93      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        | 94      | NC              |      |       |                                                                                 |
|        |        |        | 95      | LDO_CAP         | A    | MFP0  | LDO output pin.<br>Note: This pin needs to be connected with a 1uF capacitor.   |
|        |        |        | 96      | NC              |      |       |                                                                                 |
|        |        |        | 97      | PE.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                   |
|        |        |        |         | SPIM_D2         | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.                                              |
|        |        |        |         | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.                                              |
|        |        |        |         | CAN1_TXD        | O    | MFP9  | CAN1 bus transmitter output.                                                    |
|        |        |        |         | QEI1_INDEX      | I    | MFP11 | Quadrature encoder 1 index input                                                |
|        |        |        |         | EPWM0_CH0       | I/O  | MFP12 | EPWM0 channel 0 output/capture input.                                           |
|        |        |        |         | BPWM0_CH5       | I/O  | MFP13 | BPWM0 channel 5 output/capture input.                                           |
|        |        |        | 98      | PE.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | SD0_CLK         | O    | MFP3  | SD/SDIO0 clock output pin                                                       |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------|
|        |        |        |         | SPI_M_D3     | I/O  | MFP4  | SPIM data 3 pin for Quad Mode I/O.    |
|        |        |        |         | SPI3_I2SMCLK | I/O  | MFP5  | SPI3 I2S master clock output pin      |
|        |        |        |         | SC0_nCD      | I    | MFP6  | Smart Card 0 card detect pin.         |
|        |        |        |         | USCI0_CTL0   | I/O  | MFP7  | USCI0 control 0 pin.                  |
|        |        |        |         | UART5_RXD    | I    | MFP8  | UART5 data receiver input pin.        |
|        |        |        |         | CAN1_RXD     | I    | MFP9  | CAN1 bus receiver input.              |
|        |        |        |         | QEI1_A       | I    | MFP11 | Quadrature encoder 1 phase A input    |
|        |        |        |         | EPWM0_CH1    | I/O  | MFP12 | EPWM0 channel 1 output/capture input. |
|        |        |        |         | BPWM0_CH4    | I/O  | MFP13 | BPWM0 channel 4 output/capture input. |
|        |        |        |         | PE.5         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        | 99      | EBI_nRD      | O    | MFP2  | EBI read enable output pin.           |
|        |        |        |         | SD0_DAT3     | I/O  | MFP3  | SD/SDIO0 data line bit 3.             |
|        |        |        |         | SPIM_SS      | I/O  | MFP4  | SPIM slave select pin.                |
|        |        |        |         | SPI3_SS      | I/O  | MFP5  | SPI3 slave select pin.                |
|        |        |        |         | SC0_PWR      | O    | MFP6  | Smart Card 0 power pin.               |
|        |        |        |         | USCI0_CTL1   | I/O  | MFP7  | USCI0 control 1 pin.                  |
|        |        |        |         | QEI1_B       | I    | MFP11 | Quadrature encoder 1 phase B input    |
|        |        |        |         | EPWM0_CH2    | I/O  | MFP12 | EPWM0 channel 2 output/capture input. |
|        |        |        |         | BPWM0_CH3    | I/O  | MFP13 | BPWM0 channel 3 output/capture input. |
|        |        |        |         | PE.4         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        | 100     | EBI_nWR      | O    | MFP2  | EBI write enable output pin.          |
|        |        |        |         | SD0_DAT2     | I/O  | MFP3  | SD/SDIO0 data line bit 2.             |
|        |        |        |         | SPIM_CLK     | I/O  | MFP4  | SPIM serial clock pin.                |
|        |        |        |         | SPI3_CLK     | I/O  | MFP5  | SPI3 serial clock pin.                |
|        |        |        |         | SC0_RST      | O    | MFP6  | Smart Card 0 reset pin.               |
|        |        |        |         | USCI0_DAT1   | I/O  | MFP7  | USCI0 data 1 pin.                     |
|        |        |        |         | QEI0_INDEX   | I    | MFP11 | Quadrature encoder 0 index input      |
|        |        |        |         | EPWM0_CH3    | I/O  | MFP12 | EPWM0 channel 3 output/capture input. |
|        |        |        |         | BPWM0_CH2    | I/O  | MFP13 | BPWM0 channel 2 output/capture input. |
|        |        |        |         | PE.3         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        | 101     | EBI_MCLK     | O    | MFP2  | EBI external clock output pin.        |
|        |        |        |         | SD0_DAT1     | I/O  | MFP3  | SD/SDIO0 data line bit 1.             |
|        |        |        |         | SPIM_MISO    | I/O  | MFP4  | SPIM MISO (Master In, Slave Out) pin. |
|        |        |        |         | SPI3_MISO    | I/O  | MFP5  | SPI3 MISO (Master In, Slave Out) pin. |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        |         | SC0_DAT         | I/O  | MFP6  | Smart Card 0 data pin.                                                          |
|        |        |        |         | USCI0_DAT0      | I/O  | MFP7  | USCI0 data 0 pin.                                                               |
|        |        |        |         | QEIO_A          | I    | MFP11 | Quadrature encoder 0 phase A input                                              |
|        |        |        |         | EPWM0_CH4       | I/O  | MFP12 | EPWM0 channel 4 output/capture input.                                           |
|        |        |        |         | BPWM0_CH1       | I/O  | MFP13 | BPWM0 channel 1 output/capture input.                                           |
|        |        |        | 102     | PE.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ALE         | O    | MFP2  | EBI address latch enable output pin.                                            |
|        |        |        |         | SD0_DAT0        | I/O  | MFP3  | SD/SDIO0 data line bit 0.                                                       |
|        |        |        |         | SPI_MOSI        | I/O  | MFP4  | SPI_MOSI (Master Out, Slave In) pin.                                            |
|        |        |        |         | SPI3_MOSI       | I/O  | MFP5  | SPI3 MOSI (Master Out, Slave In) pin.                                           |
|        |        |        |         | SC0_CLK         | O    | MFP6  | Smart Card 0 clock pin.                                                         |
|        |        |        |         | USCI0_CLK       | I/O  | MFP7  | USCI0 clock pin.                                                                |
|        |        |        |         | QEIO_B          | I    | MFP11 | Quadrature encoder 0 phase B input                                              |
|        |        |        |         | EPWM0_CH5       | I/O  | MFP12 | EPWM0 channel 5 output/capture input.                                           |
|        |        |        |         | BPWM0_CH0       | I/O  | MFP13 | BPWM0 channel 0 output/capture input.                                           |
|        |        |        | 103     | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        |         | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        |         | PE.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD10        | I/O  | MFP2  | EBI address/data bus bit 10.                                                    |
|        |        |        |         | QSPI0_MISO0     | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin.                                     |
|        |        |        |         | SC2_DAT         | I/O  | MFP4  | Smart Card 2 data pin.                                                          |
|        |        |        |         | I2S0_BCLK       | O    | MFP5  | I2S0 bit clock output pin.                                                      |
|        |        |        |         | SPI1_MISO       | I/O  | MFP6  | SPI1 MISO (Master In, Slave Out) pin.                                           |
|        |        |        |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |        |        |         | I2C1_SCL        | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |        |        | 105     | UART4_nCTS      | I    | MFP9  | UART4 clear to Send input pin.                                                  |
|        |        |        |         | PE.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |        |        |         | QSPI0_MOSI0     | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.                                     |
|        |        |        |         | SC2_CLK         | O    | MFP4  | Smart Card 2 clock pin.                                                         |
|        |        |        |         | I2S0_MCLK       | O    | MFP5  | I2S0 master clock output pin.                                                   |
|        |        |        |         | SPI1_MOSI       | I/O  | MFP6  | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|        |        |        | 106     | UART3_RXD       | I    | MFP7  | UART3 data receiver input pin.                                                  |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | I2C1_SDA     | I/O  | MFP8  | I2C1 data input/output pin.                 |
|        |        |        |         | UART4_nRTS   | O    | MFP9  | UART4 request to Send output pin.           |
|        |        | 107    | PH.8    | PH.8         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD12     | I/O  | MFP2  | EBI address/data bus bit 12.                |
|        |        |        |         | QSPI0_CLK    | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |        |        |         | SC2_PWR      | O    | MFP4  | Smart Card 2 power pin.                     |
|        |        |        |         | I2S0_DI      | I    | MFP5  | I2S0 data input pin.                        |
|        |        |        |         | SPI1_CLK     | I/O  | MFP6  | SPI1 serial clock pin.                      |
|        |        |        |         | UART3_nRTS   | O    | MFP7  | UART3 request to Send output pin.           |
|        |        |        |         | I2C1_SMBAL   | O    | MFP8  | I2C1 SMBus SMBALTER pin                     |
|        |        |        |         | I2C2_SCL     | I/O  | MFP9  | I2C2 clock pin.                             |
|        |        |        |         | UART1_TXD    | O    | MFP10 | UART1 data transmitter output pin.          |
|        |        | 108    | PH.9    | PH.9         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD13     | I/O  | MFP2  | EBI address/data bus bit 13.                |
|        |        |        |         | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                 |
|        |        |        |         | SC2_RST      | O    | MFP4  | Smart Card 2 reset pin.                     |
|        |        |        |         | I2S0_DO      | O    | MFP5  | I2S0 data output pin.                       |
|        |        |        |         | SPI1_SS      | I/O  | MFP6  | SPI1 slave select pin.                      |
|        |        |        |         | UART3_nCTS   | I    | MFP7  | UART3 clear to Send input pin.              |
|        |        |        |         | I2C1_SMBSUS  | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |        |        |         | I2C2_SDA     | I/O  | MFP9  | I2C2 data input/output pin.                 |
|        |        |        |         | UART1_RXD    | I    | MFP10 | UART1 data receiver input pin.              |
|        |        | 109    | PH.10   | PH.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD14     | I/O  | MFP2  | EBI address/data bus bit 14.                |
|        |        |        |         | QSPI0_MISO1  | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |        |        |         | SC2_nCD      | I    | MFP4  | Smart Card 2 card detect pin.               |
|        |        |        |         | I2S0_LRCK    | O    | MFP5  | I2S0 left right channel clock output pin.   |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP6  | SPI1 I2S master clock output pin            |
|        |        |        |         | UART4_TXD    | O    | MFP7  | UART4 data transmitter output pin.          |
|        |        |        |         | UART0_TXD    | O    | MFP8  | UART0 data transmitter output pin.          |
|        |        | 110    | PH.11   | PH.11        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD15     | I/O  | MFP2  | EBI address/data bus bit 15.                |
|        |        |        |         | QSPI0_MOSI1  | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |        |        |         | UART4_RXD    | I    | MFP7  | UART4 data receiver input pin.              |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        |         | UART0_RXD       | I    | MFP8  | UART0 data receiver input pin.                                                  |
|        |        |        |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |        |        | 111     | PD.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_nCS0        | O    | MFP2  | EBI chip select 0 output pin.                                                   |
|        |        |        |         | SPI3_I2SMCLK    | I/O  | MFP3  | SPI3 I2S master clock output pin                                                |
|        |        |        |         | SC1_nCD         | I    | MFP4  | Smart Card 1 card detect pin.                                                   |
|        |        |        |         | EPWM0_CH4       | I/O  | MFP11 | EPWM0 channel 4 output/capture input.                                           |
| 25     | 37     | 49     | 112     | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 26     | 38     | 50     | 113     | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |
| 27     | 39     | 51     | 114     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 115     | PC.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |        |        |         | SC1_nCD         | I    | MFP3  | Smart Card 1 card detect pin.                                                   |
|        |        |        |         | SPI0_I2SMCLK    | I/O  | MFP4  | SPI0 I2S master clock output pin                                                |
|        |        |        |         | USCI0_CTL0      | I/O  | MFP5  | USCI0 control 0 pin.                                                            |
|        |        |        |         | QSPI0_CLK       | I/O  | MFP6  | Quad SPI0 serial clock pin.                                                     |
|        |        |        |         | EPWM0_SYNC_IN   | I    | MFP11 | EPWM0 counter synchronous trigger input pin.                                    |
|        |        |        |         | TM1             | I/O  | MFP13 | Timer1 event counter input/toggle output pin.                                   |
|        |        |        |         | USB_VBUS_ST     | I    | MFP14 | USB external VBUS regulator status pin.                                         |
|        |        |        | 116     | PB.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EADC0_CH15      | A    | MFP1  | EADC0 channel 15 analog input.                                                  |
|        |        |        |         | EBI_AD12        | I/O  | MFP2  | EBI address/data bus bit 12.                                                    |
|        |        |        |         | SC1_PWR         | O    | MFP3  | Smart Card 1 power pin.                                                         |
|        |        |        |         | SPI0_SS         | I/O  | MFP4  | SPI0 slave select pin.                                                          |
|        |        |        |         | USCI0_CTL1      | I/O  | MFP5  | USCI0 control 1 pin.                                                            |
|        |        |        |         | UART0_nCTS      | I    | MFP6  | UART0 clear to Send input pin.                                                  |
|        |        |        |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |        |        |         | I2C2_SMBAL      | O    | MFP8  | I2C2 SMBus SMBALTER pin                                                         |
|        |        |        |         | EPWM1_CH0       | I/O  | MFP11 | EPWM1 channel 0 output/capture input.                                           |
|        |        |        |         | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
|        |        |        |         | USB_VBUS_EN     | O    | MFP14 | USB external VBUS regulator enable pin.                                         |
|        |        |        | 117     | PB.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EADC0_CH14      | A    | MFP1  | EADC0 channel 14 analog input.                                                  |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                      |
|--------|--------|--------|---------|-------------|------|-------|--------------------------------------------------|
|        |        |        |         | EBI_AD13    | I/O  | MFP2  | EBI address/data bus bit 13.                     |
|        |        |        |         | SC1_RST     | O    | MFP3  | Smart Card 1 reset pin.                          |
|        |        |        |         | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                           |
|        |        |        |         | USCI0_DAT1  | I/O  | MFP5  | USCI0 data 1 pin.                                |
|        |        |        |         | UART0_nRTS  | O    | MFP6  | UART0 request to Send output pin.                |
|        |        |        |         | UART3_RXD   | I    | MFP7  | UART3 data receiver input pin.                   |
|        |        |        |         | I2C2_SMBSUS | O    | MFP8  | I2C2 SMBus SMBSUS pin (PMBus CONTROL pin)        |
|        |        |        |         | EPWM1_CH1   | I/O  | MFP11 | EPWM1 channel 1 output/capture input.            |
|        |        |        |         | TM1_EXT     | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |        |        |         | CLKO        | O    | MFP14 | Clock Out                                        |
| 30     | 43     | 55     | 118     | PB.13       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | EADC0_CH13  | A    | MFP1  | EADC0 channel 13 analog input.                   |
|        |        |        |         | DAC1_OUT    | A    | MFP1  | DAC1 channel analog output.                      |
|        |        |        |         | ACMP0_P3    | A    | MFP1  | Analog comparator 0 positive input 3 pin.        |
|        |        |        |         | ACMP1_P3    | A    | MFP1  | Analog comparator 1 positive input 3 pin.        |
|        |        |        |         | EBI_AD14    | I/O  | MFP2  | EBI address/data bus bit 14.                     |
|        |        |        |         | SC1_DAT     | I/O  | MFP3  | Smart Card 1 data pin.                           |
|        |        |        |         | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.            |
|        |        |        |         | USCI0_DAT0  | I/O  | MFP5  | USCI0 data 0 pin.                                |
|        |        |        |         | UART0_TXD   | O    | MFP6  | UART0 data transmitter output pin.               |
|        |        |        |         | UART3_nRTS  | O    | MFP7  | UART3 request to Send output pin.                |
|        |        |        |         | I2C2_SCL    | I/O  | MFP8  | I2C2 clock pin.                                  |
|        |        |        |         | EPWM1_CH2   | I/O  | MFP11 | EPWM1 channel 2 output/capture input.            |
|        |        |        |         | TM2_EXT     | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
| 31     | 44     | 56     | 119     | PB.12       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | EADC0_CH12  | A    | MFP1  | EADC0 channel 12 analog input.                   |
|        |        |        |         | DAC0_OUT    | A    | MFP1  | DAC0 channel analog output.                      |
|        |        |        |         | ACMP0_P2    | A    | MFP1  | Analog comparator 0 positive input 2 pin.        |
|        |        |        |         | ACMP1_P2    | A    | MFP1  | Analog comparator 1 positive input 2 pin.        |
|        |        |        |         | EBI_AD15    | I/O  | MFP2  | EBI address/data bus bit 15.                     |
|        |        |        |         | SC1_CLK     | O    | MFP3  | Smart Card 1 clock pin.                          |
|        |        |        |         | SPI0_MOSI   | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.            |
|        |        |        |         | USCI0_CLK   | I/O  | MFP5  | USCI0 clock pin.                                 |
|        |        |        |         | UART0_RXD   | I    | MFP6  | UART0 data receiver input pin.                   |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name         | Type | MFP   | Description                                                                                |
|--------|--------|--------|---------|------------------|------|-------|--------------------------------------------------------------------------------------------|
|        |        |        |         | UART3_nCTS       | I    | MFP7  | UART3 clear to Send input pin.                                                             |
|        |        |        |         | I2C2_SDA         | I/O  | MFP8  | I2C2 data input/output pin.                                                                |
|        |        |        |         | SD0_nCD          | I    | MFP9  | SD/SDIO0 card detect input pin                                                             |
|        |        |        |         | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                                                      |
|        |        |        |         | TM3_EXT          | I/O  | MFP13 | Timer3 external capture input/toggle output pin.                                           |
| 32     | 45     | 57     | 120     | AV <sub>DD</sub> | P    | MFP0  | Power supply for internal analog circuit.                                                  |
|        |        | 58     | 121     | V <sub>REF</sub> | A    | MFP0  | ADC reference voltage input.<br>Note: This pin needs to be connected with a 1uF capacitor. |
|        | 46     | 59     | 122     | AV <sub>ss</sub> | P    | MFP0  | Ground pin for analog circuit.                                                             |
|        |        |        |         | PB.11            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        |         | EADC0_CH11       | A    | MFP1  | EADC0 channel 11 analog input.                                                             |
|        |        |        |         | EBI_ADR16        | O    | MFP2  | EBI address bus bit 16.                                                                    |
|        |        |        |         | UART0_nCTS       | I    | MFP5  | UART0 clear to Send input pin.                                                             |
|        |        |        |         | UART4_TXD        | O    | MFP6  | UART4 data transmitter output pin.                                                         |
|        |        |        |         | I2C1_SCL         | I/O  | MFP7  | I2C1 clock pin.                                                                            |
|        |        |        |         | CAN0_TXD         | O    | MFP8  | CAN0 bus transmitter output.                                                               |
|        |        |        |         | SPI0_I2SMCLK     | I/O  | MFP9  | SPI0 I2S master clock output pin                                                           |
|        |        |        |         | BPWM1_CH0        | I/O  | MFP10 | BPWM1 channel 0 output/capture input.                                                      |
|        |        |        |         | SPI3_CLK         | I/O  | MFP11 | SPI3 serial clock pin.                                                                     |
|        |        |        |         | PB.10            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        |         | EADC0_CH10       | A    | MFP1  | EADC0 channel 10 analog input.                                                             |
|        |        |        |         | EBI_ADR17        | O    | MFP2  | EBI address bus bit 17.                                                                    |
|        |        |        |         | USCI1_CTL0       | I/O  | MFP4  | USCI1 control 0 pin.                                                                       |
|        |        |        |         | UART0_nRTS       | O    | MFP5  | UART0 request to Send output pin.                                                          |
|        |        |        |         | UART4_RXD        | I    | MFP6  | UART4 data receiver input pin.                                                             |
|        |        |        |         | I2C1_SDA         | I/O  | MFP7  | I2C1 data input/output pin.                                                                |
|        |        |        |         | CAN0_RXD         | I    | MFP8  | CAN0 bus receiver input.                                                                   |
|        |        |        |         | BPWM1_CH1        | I/O  | MFP10 | BPWM1 channel 1 output/capture input.                                                      |
|        |        |        |         | SPI3_SS          | I/O  | MFP11 | SPI3 slave select pin.                                                                     |
|        |        |        |         | PB.9             | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        |         | EADC0_CH9        | A    | MFP1  | EADC0 channel 9 analog input.                                                              |
|        |        |        |         | EBI_ADR18        | O    | MFP2  | EBI address bus bit 18.                                                                    |
|        |        |        |         | USCI1_CTL1       | I/O  | MFP4  | USCI1 control 1 pin.                                                                       |
|        |        |        |         | UART0_TXD        | O    | MFP5  | UART0 data transmitter output pin.                                                         |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type         | MFP   | Description                               |                                         |
|--------|--------|--------|---------|-------------|--------------|-------|-------------------------------------------|-----------------------------------------|
|        |        |        |         | UART1_nCTS  | I            | MFP6  | UART1 clear to Send input pin.            |                                         |
|        |        |        |         | I2C1_SMBAL  | O            | MFP7  | I2C1 SMBus SMBALTER pin                   |                                         |
|        |        |        |         | BPWM1_CH2   | I/O          | MFP10 | BPWM1 channel 2 output/capture input.     |                                         |
|        |        |        |         | SPI3_MISO   | I/O          | MFP11 | SPI3 MISO (Master In, Slave Out) pin.     |                                         |
|        |        |        |         | INT7        | I            | MFP13 | External interrupt 7 input pin.           |                                         |
|        |        | 63     | 126     | PB.8        | I/O          | MFP0  | General purpose digital I/O pin.          |                                         |
|        |        |        |         | EADC0_CH8   | A            | MFP1  | EADC0 channel 8 analog input.             |                                         |
|        |        |        |         | EBI_ADR19   | O            | MFP2  | EBI address bus bit 19.                   |                                         |
|        |        |        |         | USCI1_CLK   | I/O          | MFP4  | USCI1 clock pin.                          |                                         |
|        |        |        |         | UART0_RXD   | I            | MFP5  | UART0 data receiver input pin.            |                                         |
|        |        |        |         | UART1_nRTS  | O            | MFP6  | UART1 request to Send output pin.         |                                         |
|        |        |        |         | I2C1_SMBSUS | O            | MFP7  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |                                         |
|        |        |        |         | BPWM1_CH3   | I/O          | MFP10 | BPWM1 channel 3 output/capture input.     |                                         |
|        |        |        |         | SPI3_MOSI   | I/O          | MFP11 | SPI3 MOSI (Master Out, Slave In) pin.     |                                         |
|        |        |        |         | INT6        | I            | MFP13 | External interrupt 6 input pin.           |                                         |
|        |        | 47     | 64      | 127         | PB.7         | I/O   | MFP0                                      | General purpose digital I/O pin.        |
|        |        |        |         |             | EADC0_CH7    | A     | MFP1                                      | EADC0 channel 7 analog input.           |
|        |        |        |         |             | EBI_nWRL     | O     | MFP2                                      | EBI low byte write enable output pin.   |
|        |        |        |         |             | USCI1_DAT0   | I/O   | MFP4                                      | USCI1 data 0 pin.                       |
|        |        |        |         |             | CAN1_TXD     | O     | MFP5                                      | CAN1 bus transmitter output.            |
|        |        |        |         |             | UART1_TXD    | O     | MFP6                                      | UART1 data transmitter output pin.      |
|        |        |        |         |             | SD1_CMD      | I/O   | MFP7                                      | SD/SDIO1 command/response pin           |
|        |        |        |         |             | EBI_nCS0     | O     | MFP8                                      | EBI chip select 0 output pin.           |
|        |        |        |         |             | BPWM1_CH4    | I/O   | MFP10                                     | BPWM1 channel 4 output/capture input.   |
|        |        |        |         |             | EPWM1_BRAKE0 | I     | MFP11                                     | EPWM1 Brake 0 input pin.                |
|        |        |        |         |             | EPWM1_CH4    | I/O   | MFP12                                     | EPWM1 channel 4 output/capture input.   |
|        |        |        |         |             | INT5         | I     | MFP13                                     | External interrupt 5 input pin.         |
|        |        |        |         |             | USB_VBUS_ST  | I     | MFP14                                     | USB external VBUS regulator status pin. |
|        |        |        |         |             | ACMP0_O      | O     | MFP15                                     | Analog comparator 0 output pin.         |
|        |        | 48     | 1       | 128         | PB.6         | I/O   | MFP0                                      | General purpose digital I/O pin.        |
|        |        |        |         |             | EADC0_CH6    | A     | MFP1                                      | EADC0 channel 6 analog input.           |
|        |        |        |         |             | EBI_nWRH     | O     | MFP2                                      | EBI high byte write enable output pin   |
|        |        |        |         |             | USCI1_DAT1   | I/O   | MFP4                                      | USCI1 data 1 pin.                       |
|        |        |        |         |             | CAN1_RXD     | I     | MFP5                                      | CAN1 bus receiver input.                |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                             |
|--------|--------|--------|---------|--------------|------|-------|-----------------------------------------|
|        |        |        |         | UART1_RXD    | I    | MFP6  | UART1 data receiver input pin.          |
|        |        |        |         | SD1_CLK      | O    | MFP7  | SD/SDIO1 clock output pin               |
|        |        |        |         | EBI_nCS1     | O    | MFP8  | EBI chip select 1 output pin.           |
|        |        |        |         | BPWM1_CH5    | I/O  | MFP10 | BPWM1 channel 5 output/capture input.   |
|        |        |        |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.                |
|        |        |        |         | EPWM1_CH5    | I/O  | MFP12 | EPWM1 channel 5 output/capture input.   |
|        |        |        |         | INT4         | I    | MFP13 | External interrupt 4 input pin.         |
|        |        |        |         | USB_VBUS_EN  | O    | MFP14 | USB external VBUS regulator enable pin. |
|        |        |        |         | ACMP1_O      | O    | MFP15 | Analog comparator 1 output pin.         |

## 4.2.3 M483 Series Pin Description

| 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|---------|------------|------|-------|-----------------------------------------------|
| 2      | 1       | PB.5       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EADC0_CH5  | A    | MFP1  | EADC0 channel 5 analog input.                 |
|        |         | ACMP1_N    | A    | MFP1  | Analog comparator 1 negative input pin.       |
|        |         | EBI_ADR0   | O    | MFP2  | EBI address bus bit 0.                        |
|        |         | SD0_DAT3   | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|        |         | SPI1_MISO  | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |         | I2C0_SCL   | I/O  | MFP6  | I2C0 clock pin.                               |
|        |         | UART5_TXD  | O    | MFP7  | UART5 data transmitter output pin.            |
|        |         | USCI1_CTL0 | I/O  | MFP8  | USCI1 control 0 pin.                          |
|        |         | SC0_CLK    | O    | MFP9  | Smart Card 0 clock pin.                       |
|        |         | I2S0_BCLK  | O    | MFP10 | I2S0 bit clock output pin.                    |
|        |         | EPWM0_CH0  | I/O  | MFP11 | EPWM0 channel 0 output/capture input.         |
|        |         | TM0        | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |         | INT0       | I    | MFP15 | External interrupt 0 input pin.               |
| 3      | 2       | PB.4       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EADC0_CH4  | A    | MFP1  | EADC0 channel 4 analog input.                 |
|        |         | ACMP1_P1   | A    | MFP1  | Analog comparator 1 positive input 1 pin.     |
|        |         | EBI_ADR1   | O    | MFP2  | EBI address bus bit 1.                        |
|        |         | SD0_DAT2   | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|        |         | SPI1_MOSI  | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |         | I2C0_SDA   | I/O  | MFP6  | I2C0 data input/output pin.                   |
|        |         | UART5_RXD  | I    | MFP7  | UART5 data receiver input pin.                |
|        |         | USCI1_CTL1 | I/O  | MFP8  | USCI1 control 1 pin.                          |
|        |         | SC0_DAT    | I/O  | MFP9  | Smart Card 0 data pin.                        |
|        |         | I2S0_MCLK  | O    | MFP10 | I2S0 master clock output pin.                 |
|        |         | EPWM0_CH1  | I/O  | MFP11 | EPWM0 channel 1 output/capture input.         |
|        |         | TM1        | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
|        |         | INT1       | I    | MFP15 | External interrupt 1 input pin.               |
| 4      | 3       | PB.3       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EADC0_CH3  | A    | MFP1  | EADC0 channel 3 analog input.                 |
|        |         | ACMP0_N    | A    | MFP1  | Analog comparator 0 negative input pin.       |
|        |         | EBI_ADR2   | O    | MFP2  | EBI address bus bit 2.                        |
|        |         | SD0_DAT1   | I/O  | MFP3  | SD/SDIO0 data line bit 1.                     |

| 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|---------|------------|------|-------|-----------------------------------------------|
|        |         | SPI1_CLK   | I/O  | MFP5  | SPI1 serial clock pin.                        |
|        |         | UART1_TXD  | O    | MFP6  | UART1 data transmitter output pin.            |
|        |         | UART5_nRTS | O    | MFP7  | UART5 request to Send output pin.             |
|        |         | USCI1_DAT1 | I/O  | MFP8  | USCI1 data 1 pin.                             |
|        |         | SC0_RST    | O    | MFP9  | Smart Card 0 reset pin.                       |
|        |         | I2S0_DI    | I    | MFP10 | I2S0 data input pin.                          |
|        |         | EPWM0_CH2  | I/O  | MFP11 | EPWM0 channel 2 output/capture input.         |
|        |         | TM2        | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|        |         | INT2       | I    | MFP15 | External interrupt 2 input pin.               |
|        | 5       | PB.2       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EADC0_CH2  | A    | MFP1  | EADC0 channel 2 analog input.                 |
|        |         | ACMP0_P1   | A    | MFP1  | Analog comparator 0 positive input 1 pin.     |
|        |         | OPA0_O     | A    | MFP1  | Operational amplifier 0 output pin.           |
|        |         | EBI_ADR3   | O    | MFP2  | EBI address bus bit 3.                        |
|        |         | SD0_DAT0   | I/O  | MFP3  | SD/SDIO0 data line bit 0.                     |
|        |         | SPI1_SS    | I/O  | MFP5  | SPI1 slave select pin.                        |
|        |         | UART1_RXD  | I    | MFP6  | UART1 data receiver input pin.                |
|        |         | UART5_nCTS | I    | MFP7  | UART5 clear to Send input pin.                |
|        |         | USCI1_DAT0 | I/O  | MFP8  | USCI1 data 0 pin.                             |
|        |         | SC0_PWR    | O    | MFP9  | Smart Card 0 power pin.                       |
|        |         | I2S0_DO    | O    | MFP10 | I2S0 data output pin.                         |
|        |         | EPWM0_CH3  | I/O  | MFP11 | EPWM0 channel 3 output/capture input.         |
|        |         | TM3        | I/O  | MFP14 | Timer3 event counter input/toggle output pin. |
|        |         | INT3       | I    | MFP15 | External interrupt 3 input pin.               |
|        |         | PC.12      | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR4   | O    | MFP2  | EBI address bus bit 4.                        |
|        |         | UART0_TXD  | O    | MFP3  | UART0 data transmitter output pin.            |
|        |         | I2C0_SCL   | I/O  | MFP4  | I2C0 clock pin.                               |
|        |         | SPI3_MISO  | I/O  | MFP6  | SPI3 MISO (Master In, Slave Out) pin.         |
|        |         | SC0_nCD    | I    | MFP9  | Smart Card 0 card detect pin.                 |
|        |         | ECAP1_IC2  | I    | MFP11 | Enhanced capture unit 1 input 2 pin.          |
|        |         | EPWM1_CH0  | I/O  | MFP12 | EPWM1 channel 0 output/capture input.         |
|        |         | ACMP0_O    | O    | MFP14 | Analog comparator 0 output pin.               |
|        | 6       | PC.11      | I/O  | MFP0  | General purpose digital I/O pin.              |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|---------|--------------|------|-------|---------------------------------------------|
|        |         | EBI_ADR5     | O    | MFP2  | EBI address bus bit 5.                      |
|        |         | UART0_RXD    | I    | MFP3  | UART0 data receiver input pin.              |
|        |         | I2C0_SDA     | I/O  | MFP4  | I2C0 data input/output pin.                 |
|        |         | SPI3_MOSI    | I/O  | MFP6  | SPI3 MOSI (Master Out, Slave In) pin.       |
|        |         | ECAP1_IC1    | I    | MFP11 | Enhanced capture unit 1 input 1 pin.        |
|        |         | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        |         | ACMP1_O      | O    | MFP14 | Analog comparator 1 output pin.             |
|        | 7       | PC.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_ADR6     | O    | MFP2  | EBI address bus bit 6.                      |
|        |         | SPI3_CLK     | I/O  | MFP6  | SPI3 serial clock pin.                      |
|        |         | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.          |
|        |         | CAN1_TXD     | O    | MFP9  | CAN1 bus transmitter output.                |
|        |         | ECAP1_IC0    | I    | MFP11 | Enhanced capture unit 1 input 0 pin.        |
|        |         | EPWM1_CH2    | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        | 8       | PC.9         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_ADR7     | O    | MFP2  | EBI address bus bit 7.                      |
|        |         | SPI3_SS      | I/O  | MFP6  | SPI3 slave select pin.                      |
|        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.              |
|        |         | CAN1_RXD     | I    | MFP9  | CAN1 bus receiver input.                    |
|        |         | EPWM1_CH3    | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        | 9       | PB.1         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EADC0_CH1    | A    | MFP1  | EADC0 channel 1 analog input.               |
|        |         | OPA0_N       | A    | MFP1  | Operational amplifier 0 negative input pin. |
|        |         | EBI_ADR8     | O    | MFP2  | EBI address bus bit 8.                      |
|        |         | SD0_CLK      | O    | MFP3  | SD/SDIO0 clock output pin                   |
|        |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin            |
|        |         | SPI3_I2SMCLK | I/O  | MFP6  | SPI3 I2S master clock output pin            |
|        |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.          |
|        |         | USCI1_CLK    | I/O  | MFP8  | USCI1 clock pin.                            |
|        |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |         | I2S0_LRCK    | O    | MFP10 | I2S0 left right channel clock output pin.   |
|        |         | EPWM0_CH4    | I/O  | MFP11 | EPWM0 channel 4 output/capture input.       |
|        |         | EPWM1_CH4    | I/O  | MFP12 | EPWM1 channel 4 output/capture input.       |
|        |         | EPWM0_BRAKE0 | I    | MFP13 | EPWM0 Brake 0 input pin.                    |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
| 7      | 10      | PB.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EADC0_CH0       | A    | MFP1  | EADC0 channel 0 analog input.                                                   |
|        |         | OPA0_P          | A    | MFP1  | Operational amplifier 0 positive input pin.                                     |
|        |         | EBI_ADR9        | O    | MFP2  | EBI address bus bit 9.                                                          |
|        |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                   |
|        |         | UART2_RXD       | I    | MFP7  | UART2 data receiver input pin.                                                  |
|        |         | SPI0_I2SMCLK    | I/O  | MFP8  | SPI0 I2S master clock output pin                                                |
|        |         | I2C1_SDA        | I/O  | MFP9  | I2C1 data input/output pin.                                                     |
|        |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |         | EPWM0_BRAKE1    | I    | MFP13 | EPWM0 Brake 1 input pin.                                                        |
|        | 11      | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        | 12      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 8      | 13      | PA.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | ACMP0_P0        | A    | MFP1  | Analog comparator 0 positive input 0 pin.                                       |
|        |         | EBI_nRD         | O    | MFP2  | EBI read enable output pin.                                                     |
|        |         | SC2_PWR         | O    | MFP3  | Smart Card 2 power pin.                                                         |
|        |         | SPI2_SS         | I/O  | MFP4  | SPI2 slave select pin.                                                          |
|        |         | SD1_DAT3        | I/O  | MFP5  | SD/SDIO1 data line bit 3.                                                       |
|        |         | USCI0_CLK       | I/O  | MFP6  | USCI0 clock pin.                                                                |
|        |         | I2C2_SCL        | I/O  | MFP7  | I2C2 clock pin.                                                                 |
|        |         | BPWM0_CH0       | I/O  | MFP9  | BPWM0 channel 0 output/capture input.                                           |
|        |         | EPWM0_SYNC_OUT  | O    | MFP10 | EPWM0 counter synchronous trigger output pin.                                   |
| 9      | 14      | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
|        |         | DAC1_ST         | I    | MFP14 | DAC1 external trigger input.                                                    |
|        |         | PA.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | ACMP1_P0        | A    | MFP1  | Analog comparator 1 positive input 0 pin.                                       |
|        |         | OPA1_O          | A    | MFP1  | Operational amplifier 1 output pin.                                             |
|        |         | EBI_nWR         | O    | MFP2  | EBI write enable output pin.                                                    |
|        |         | SC2_RST         | O    | MFP3  | Smart Card 2 reset pin.                                                         |
|        |         | SPI2_CLK        | I/O  | MFP4  | SPI2 serial clock pin.                                                          |
|        |         | SD1_DAT2        | I/O  | MFP5  | SD/SDIO1 data line bit 2.                                                       |
|        |         | USCI0_DAT0      | I/O  | MFP6  | USCI0 data 0 pin.                                                               |

| 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                      |
|--------|---------|------------|------|-------|--------------------------------------------------|
|        |         | I2C2_SDA   | I/O  | MFP7  | I2C2 data input/output pin.                      |
|        |         | BPWM0_CH1  | I/O  | MFP9  | BPWM0 channel 1 output/capture input.            |
|        |         | QEI1_INDEX | I    | MFP10 | Quadrature encoder 1 index input                 |
|        |         | ECAP0_IC0  | I    | MFP11 | Enhanced capture unit 0 input 0 pin.             |
|        |         | TM1_EXT    | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |         | DAC0_ST    | I    | MFP14 | DAC0 external trigger input.                     |
|        | 10      | PA.9       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         | OPA1_N     | A    | MFP1  | Operational amplifier 1 negative input pin.      |
|        |         | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.                   |
|        |         | SC2_DAT    | I/O  | MFP3  | Smart Card 2 data pin.                           |
|        |         | SPI2_MISO  | I/O  | MFP4  | SPI2 MISO (Master In, Slave Out) pin.            |
|        |         | SD1_DAT1   | I/O  | MFP5  | SD/SDIO1 data line bit 1.                        |
|        |         | USCI0_DAT1 | I/O  | MFP6  | USCI0 data 1 pin.                                |
|        |         | UART1_TXD  | O    | MFP7  | UART1 data transmitter output pin.               |
|        |         | BPWM0_CH2  | I/O  | MFP9  | BPWM0 channel 2 output/capture input.            |
|        |         | QEI1_A     | I    | MFP10 | Quadrature encoder 1 phase A input               |
|        |         | ECAP0_IC1  | I    | MFP11 | Enhanced capture unit 0 input 1 pin.             |
|        |         | TM2_EXT    | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|        |         | PA.8       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         | OPA1_P     | A    | MFP1  | Operational amplifier 1 positive input pin.      |
|        | 11      | EBI_ALE    | O    | MFP2  | EBI address latch enable output pin.             |
|        |         | SC2_CLK    | O    | MFP3  | Smart Card 2 clock pin.                          |
|        |         | SPI2_MOSI  | I/O  | MFP4  | SPI2 MOSI (Master Out, Slave In) pin.            |
|        |         | SD1_DAT0   | I/O  | MFP5  | SD/SDIO1 data line bit 0.                        |
|        |         | USCI0_CTL1 | I/O  | MFP6  | USCI0 control 1 pin.                             |
|        |         | UART1_RXD  | I    | MFP7  | UART1 data receiver input pin.                   |
|        |         | BPWM0_CH3  | I/O  | MFP9  | BPWM0 channel 3 output/capture input.            |
|        |         | QEI1_B     | I    | MFP10 | Quadrature encoder 1 phase B input               |
|        |         | ECAP0_IC2  | I    | MFP11 | Enhanced capture unit 0 input 2 pin.             |
|        |         | TM3_EXT    | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
|        |         | INT4       | I    | MFP15 | External interrupt 4 input pin.                  |
|        |         | PC.13      | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         | EBI_ADR10  | O    | MFP2  | EBI address bus bit 10.                          |
|        |         | SC2_nCD    | I    | MFP3  | Smart Card 2 card detect pin.                    |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|---------|--------------|------|-------|---------------------------------------------|
|        |         | SPI2_I2SMCLK | I/O  | MFP4  | SPI2 I2S master clock output pin            |
|        |         | CAN1_TXD     | O    | MFP5  | CAN1 bus transmitter output.                |
|        |         | USCI0_CTL0   | I/O  | MFP6  | USCI0 control 0 pin.                        |
|        |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.          |
|        |         | BPWM0_CH4    | I/O  | MFP9  | BPWM0 channel 4 output/capture input.       |
|        |         | CLKO         | O    | MFP13 | Clock Out                                   |
|        |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.               |
|        | 18      | PD.12        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | OPA2_O       | A    | MFP1  | Operational amplifier 2 output pin.         |
|        |         | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.               |
|        |         | CAN1_RXD     | I    | MFP5  | CAN1 bus receiver input.                    |
|        |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.              |
|        |         | BPWM0_CH5    | I/O  | MFP9  | BPWM0 channel 5 output/capture input.       |
|        |         | QEIO_INDEX   | I    | MFP10 | Quadrature encoder 0 index input            |
|        |         | CLKO         | O    | MFP13 | Clock Out                                   |
|        |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.               |
|        |         | INT5         | I    | MFP15 | External interrupt 5 input pin.             |
|        | 19      | PD.11        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | OPA2_N       | A    | MFP1  | Operational amplifier 2 negative input pin. |
|        |         | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.               |
|        |         | UART1_TXD    | O    | MFP3  | UART1 data transmitter output pin.          |
|        |         | CAN0_TXD     | O    | MFP4  | CAN0 bus transmitter output.                |
|        |         | QEIO_A       | I    | MFP10 | Quadrature encoder 0 phase A input          |
|        |         | INT6         | I    | MFP15 | External interrupt 6 input pin.             |
|        | 20      | PD.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | OPA2_P       | A    | MFP1  | Operational amplifier 2 positive input pin. |
|        |         | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.               |
|        |         | UART1_RXD    | I    | MFP3  | UART1 data receiver input pin.              |
|        |         | CAN0_RXD     | I    | MFP4  | CAN0 bus receiver input.                    |
|        |         | QEIO_B       | I    | MFP10 | Quadrature encoder 0 phase B input          |
|        |         | INT7         | I    | MFP15 | External interrupt 7 input pin.             |
|        | 21      | PG.2         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.                     |
|        |         | SPI2_SS      | I/O  | MFP3  | SPI2 slave select pin.                      |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|---------|--------------|------|-------|-----------------------------------------------|
|        |         | I2C0_SMBAL   | O    | MFP4  | I2C0 SMBus SMBALTER pin                       |
|        |         | I2C1_SCL     | I/O  | MFP5  | I2C1 clock pin.                               |
|        |         | TM0          | I/O  | MFP13 | Timer0 event counter input/toggle output pin. |
|        | 22      | PG.3         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.                       |
|        |         | SPI2_CLK     | I/O  | MFP3  | SPI2 serial clock pin.                        |
|        |         | I2C0_SMBSUS  | O    | MFP4  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)     |
|        |         | I2C1_SDA     | I/O  | MFP5  | I2C1 data input/output pin.                   |
|        |         | TM1          | I/O  | MFP13 | Timer1 event counter input/toggle output pin. |
|        | 23      | PG.4         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.                       |
|        |         | SPI2_MISO    | I/O  | MFP3  | SPI2 MISO (Master In, Slave Out) pin.         |
|        |         | TM2          | I/O  | MFP13 | Timer2 event counter input/toggle output pin. |
|        | 24      | PF.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.                       |
|        |         | SPI2_MOSI    | I/O  | MFP3  | SPI2 MOSI (Master Out, Slave In) pin.         |
|        |         | TAMPER5      | I/O  | MFP10 | TAMPER detector loop pin 5.                   |
|        |         | TM3          | I/O  | MFP13 | Timer3 event counter input/toggle output pin. |
|        | 25      | PF.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |         | SC0_nCD      | I    | MFP3  | Smart Card 0 card detect pin.                 |
|        |         | I2S0_BCLK    | O    | MFP4  | I2S0 bit clock output pin.                    |
|        |         | SPI0_I2SMCLK | I/O  | MFP5  | SPI0 I2S master clock output pin              |
|        |         | TAMPER4      | I/O  | MFP10 | TAMPER detector loop pin 4.                   |
|        | 26      | PF.9         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |         | SC0_PWR      | O    | MFP3  | Smart Card 0 power pin.                       |
|        |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.                 |
|        |         | SPI0_SS      | I/O  | MFP5  | SPI0 slave select pin.                        |
|        |         | TAMPER3      | I/O  | MFP10 | TAMPER detector loop pin 3.                   |
|        | 27      | PF.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR17    | O    | MFP2  | EBI address bus bit 17.                       |
|        |         | SC0_RST      | O    | MFP3  | Smart Card 0 reset pin.                       |
|        |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                          |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         | SPI0_CLK        | I/O  | MFP5  | SPI0 serial clock pin.                                                          |
|        |         | TAMPER2         | I/O  | MFP10 | TAMPER detector loop pin 2.                                                     |
|        | 28      | PF.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ADR18       | O    | MFP2  | EBI address bus bit 18.                                                         |
|        |         | SC0_DAT         | I/O  | MFP3  | Smart Card 0 data pin.                                                          |
|        |         | I2S0_DO         | O    | MFP4  | I2S0 data output pin.                                                           |
|        |         | SPI0_MISO       | I/O  | MFP5  | SPI0 MISO (Master In, Slave Out) pin.                                           |
|        |         | UART4_TXD       | O    | MFP6  | UART4 data transmitter output pin.                                              |
|        |         | TAMPER1         | I/O  | MFP10 | TAMPER detector loop pin 1.                                                     |
| 12     | 29      | PF.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ADR19       | O    | MFP2  | EBI address bus bit 19.                                                         |
|        |         | SC0_CLK         | O    | MFP3  | Smart Card 0 clock pin.                                                         |
|        |         | I2S0_LRCK       | O    | MFP4  | I2S0 left right channel clock output pin.                                       |
|        |         | SPI0_MOSI       | I/O  | MFP5  | SPI0 MOSI (Master Out, Slave In) pin.                                           |
|        |         | UART4_RXD       | I    | MFP6  | UART4 data receiver input pin.                                                  |
|        |         | EBI_nCS0        | O    | MFP7  | EBI chip select 0 output pin.                                                   |
|        |         | TAMPER0         | I/O  | MFP10 | TAMPER detector loop pin 0.                                                     |
| 13     | 30      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 14     | 31      | PF.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | UART2_RXD       | I    | MFP2  | UART2 data receiver input pin.                                                  |
|        |         | UART2_nCTS      | I    | MFP4  | UART2 clear to Send input pin.                                                  |
|        |         | BPWM0_CH4       | I/O  | MFP8  | BPWM0 channel 4 output/capture input.                                           |
|        |         | EPWM0_SYNC_OUT  | O    | MFP9  | EPWM0 counter synchronous trigger output pin.                                   |
|        |         | X32_IN          | I    | MFP10 | External 32.768 kHz crystal input pin.                                          |
|        |         | EADC0_ST        | I    | MFP11 | EADC0 external trigger input.                                                   |
| 15     | 32      | PF.4            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | UART2_TXD       | O    | MFP2  | UART2 data transmitter output pin.                                              |
|        |         | UART2_nRTS      | O    | MFP4  | UART2 request to Send output pin.                                               |
|        |         | BPWM0_CH5       | I/O  | MFP8  | BPWM0 channel 5 output/capture input.                                           |
|        |         | X32_OUT         | O    | MFP10 | External 32.768 kHz crystal output pin.                                         |
|        | 33      | PH.4            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ADR3        | O    | MFP2  | EBI address bus bit 3.                                                          |
|        |         | SPI1_MISO       | I/O  | MFP3  | SPI1 MISO (Master In, Slave Out) pin.                                           |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        | 34      | PH.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ADR2        | O    | MFP2  | EBI address bus bit 2.                                                          |
|        |         | SPI1_MOSI       | I/O  | MFP3  | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|        | 35      | PH.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ADR1        | O    | MFP2  | EBI address bus bit 1.                                                          |
|        |         | SPI1_CLK        | I/O  | MFP3  | SPI1 serial clock pin.                                                          |
|        | 36      | PH.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ADR0        | O    | MFP2  | EBI address bus bit 0.                                                          |
|        |         | SPI1_SS         | I/O  | MFP3  | SPI1 slave select pin.                                                          |
|        | 37      | PF.3            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_nCS0        | O    | MFP2  | EBI chip select 0 output pin.                                                   |
|        |         | UART0_TXD       | O    | MFP3  | UART0 data transmitter output pin.                                              |
|        |         | I2C0_SCL        | I/O  | MFP4  | I2C0 clock pin.                                                                 |
|        |         | XT1_IN          | I    | MFP10 | External 4~24 MHz (high speed) crystal input pin.                               |
|        |         | BPWM1_CH0       | I/O  | MFP11 | BPWM1 channel 0 output/capture input.                                           |
|        | 38      | PF.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_nCS1        | O    | MFP2  | EBI chip select 1 output pin.                                                   |
|        |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.                                                  |
|        |         | I2C0_SDA        | I/O  | MFP4  | I2C0 data input/output pin.                                                     |
|        |         | QSPI0_CLK       | I/O  | MFP5  | Quad SPI0 serial clock pin.                                                     |
|        |         | XT1_OUT         | O    | MFP10 | External 4~24 MHz (high speed) crystal output pin.                              |
|        |         | BPWM1_CH1       | I/O  | MFP11 | BPWM1 channel 1 output/capture input.                                           |
|        | 39      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        | 40      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        | 41      | PE.8            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ADR10       | O    | MFP2  | EBI address bus bit 10.                                                         |
|        |         | I2S0_BCLK       | O    | MFP4  | I2S0 bit clock output pin.                                                      |
|        |         | SPI2_CLK        | I/O  | MFP5  | SPI2 serial clock pin.                                                          |
|        |         | USCI1_CTL1      | I/O  | MFP6  | USCI1 control 1 pin.                                                            |
|        |         | UART2_TXD       | O    | MFP7  | UART2 data transmitter output pin.                                              |
|        |         | EPWM0_CH0       | I/O  | MFP10 | EPWM0 channel 0 output/capture input.                                           |
|        |         | EPWM0_BRAKE0    | I    | MFP11 | EPWM0 Brake 0 input pin.                                                        |
|        |         | ECAP0_IC0       | I    | MFP12 | Enhanced capture unit 0 input 0 pin.                                            |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|---------|--------------|------|-------|---------------------------------------|
|        |         | TRACE_CLK    | O    | MFP14 | ETM Trace Clock output pin            |
| 42     | 42      | PE.9         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.               |
|        |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.         |
|        |         | SPI2_MISO    | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin. |
|        |         | USCI1_CTL0   | I/O  | MFP6  | USCI1 control 0 pin.                  |
|        |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.        |
|        |         | EPWM0_CH1    | I/O  | MFP10 | EPWM0 channel 1 output/capture input. |
|        |         | EPWM0_BRAKE1 | I    | MFP11 | EPWM0 Brake 1 input pin.              |
|        |         | ECAP0_IC1    | I    | MFP12 | Enhanced capture unit 0 input 1 pin.  |
|        |         | TRACE_DATA0  | O    | MFP14 | ETM Trace Data 0 output pin           |
| 43     | 43      | PE.10        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.               |
|        |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                  |
|        |         | SPI2_MOSI    | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin. |
|        |         | USCI1_DAT0   | I/O  | MFP6  | USCI1 data 0 pin.                     |
|        |         | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.    |
|        |         | EPWM0_CH2    | I/O  | MFP10 | EPWM0 channel 2 output/capture input. |
|        |         | EPWM1_BRAKE0 | I    | MFP11 | EPWM1 Brake 0 input pin.              |
|        |         | ECAP0_IC2    | I    | MFP12 | Enhanced capture unit 0 input 2 pin.  |
|        |         | TRACE_DATA1  | O    | MFP14 | ETM Trace Data 1 output pin           |
| 44     | 44      | PE.11        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.               |
|        |         | I2S0_DO      | O    | MFP4  | I2S0 data output pin.                 |
|        |         | SPI2_SS      | I/O  | MFP5  | SPI2 slave select pin.                |
|        |         | USCI1_DAT1   | I/O  | MFP6  | USCI1 data 1 pin.                     |
|        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.        |
|        |         | UART1_nCTS   | I    | MFP8  | UART1 clear to Send input pin.        |
|        |         | EPWM0_CH3    | I/O  | MFP10 | EPWM0 channel 3 output/capture input. |
|        |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.              |
|        |         | ECAP1_IC2    | I    | MFP13 | Enhanced capture unit 1 input 2 pin.  |
| 45     | 45      | TRACE_DATA2  | O    | MFP14 | ETM Trace Data 2 output pin           |
|        |         | PE.12        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.               |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|---------|--------------|------|-------|-----------------------------------------------|
|        |         | I2S0_LRCK    | O    | MFP4  | I2S0 left right channel clock output pin.     |
|        |         | SPI2_I2SMCLK | I/O  | MFP5  | SPI2 I2S master clock output pin              |
|        |         | USCI1_CLK    | I/O  | MFP6  | USCI1 clock pin.                              |
|        |         | UART1_nRTS   | O    | MFP8  | UART1 request to Send output pin.             |
|        |         | EPWM0_CH4    | I/O  | MFP10 | EPWM0 channel 4 output/capture input.         |
|        |         | ECAP1_IC1    | I    | MFP13 | Enhanced capture unit 1 input 1 pin.          |
|        |         | TRACE_DATA3  | O    | MFP14 | ETM Trace Data 3 output pin                   |
|        | 46      | PE.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |         | I2C0_SCL     | I/O  | MFP4  | I2C0 clock pin.                               |
|        |         | UART4_nRTS   | O    | MFP5  | UART4 request to Send output pin.             |
|        |         | UART1_TXD    | O    | MFP8  | UART1 data transmitter output pin.            |
|        |         | EPWM0_CH5    | I/O  | MFP10 | EPWM0 channel 5 output/capture input.         |
|        |         | EPWM1_CH0    | I/O  | MFP11 | EPWM1 channel 0 output/capture input.         |
|        |         | BPWM1_CH5    | I/O  | MFP12 | BPWM1 channel 5 output/capture input.         |
|        |         | ECAP1_IC0    | I    | MFP13 | Enhanced capture unit 1 input 0 pin.          |
|        | 47      | PC.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |         | I2C0_SDA     | I/O  | MFP4  | I2C0 data input/output pin.                   |
|        |         | UART4_nCTS   | I    | MFP5  | UART4 clear to Send input pin.                |
|        |         | UART1_RXD    | I    | MFP8  | UART1 data receiver input pin.                |
|        |         | EPWM1_CH1    | I/O  | MFP11 | EPWM1 channel 1 output/capture input.         |
|        |         | BPWM1_CH4    | I/O  | MFP12 | BPWM1 channel 4 output/capture input.         |
|        | 48      | PC.7         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_AD9      | I/O  | MFP2  | EBI address/data bus bit 9.                   |
|        |         | SPI1_MISO    | I/O  | MFP4  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |         | UART4_TXD    | O    | MFP5  | UART4 data transmitter output pin.            |
|        |         | SC2_PWR      | O    | MFP6  | Smart Card 2 power pin.                       |
|        |         | UART0_nCTS   | I    | MFP7  | UART0 clear to Send input pin.                |
|        |         | I2C1_SMBAL   | O    | MFP8  | I2C1 SMBus SMBALTER pin                       |
|        |         | EPWM1_CH2    | I/O  | MFP11 | EPWM1 channel 2 output/capture input.         |
|        |         | BPWM1_CH0    | I/O  | MFP12 | BPWM1 channel 0 output/capture input.         |
|        |         | TM0          | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |         | INT3         | I    | MFP15 | External interrupt 3 input pin.               |

| 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                   |
|--------|---------|-------------|------|-------|-----------------------------------------------|
| 19     | 49      | PC.6        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_AD8     | I/O  | MFP2  | EBI address/data bus bit 8.                   |
|        |         | SPI1_MOSI   | I/O  | MFP4  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |         | UART4_RXD   | I    | MFP5  | UART4 data receiver input pin.                |
|        |         | SC2_RST     | O    | MFP6  | Smart Card 2 reset pin.                       |
|        |         | UART0_nRTS  | O    | MFP7  | UART0 request to Send output pin.             |
|        |         | I2C1_SMBSUS | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)     |
|        |         | EPWM1_CH3   | I/O  | MFP11 | EPWM1 channel 3 output/capture input.         |
|        |         | BPWM1_CH1   | I/O  | MFP12 | BPWM1 channel 1 output/capture input.         |
|        |         | TM1         | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
| 20     | 50      | INT2        | I    | MFP15 | External interrupt 2 input pin.               |
|        |         | PA.7        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_AD7     | I/O  | MFP2  | EBI address/data bus bit 7.                   |
|        |         | SPI1_CLK    | I/O  | MFP4  | SPI1 serial clock pin.                        |
|        |         | SC2_DAT     | I/O  | MFP6  | Smart Card 2 data pin.                        |
|        |         | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.            |
|        |         | I2C1_SCL    | I/O  | MFP8  | I2C1 clock pin.                               |
|        |         | EPWM1_CH4   | I/O  | MFP11 | EPWM1 channel 4 output/capture input.         |
|        |         | BPWM1_CH2   | I/O  | MFP12 | BPWM1 channel 2 output/capture input.         |
|        |         | ACMP0_WLAT  | I    | MFP13 | Analog comparator 0 window latch input pin    |
| 21     | 51      | TM2         | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|        |         | INT1        | I    | MFP15 | External interrupt 1 input pin.               |
|        |         | PA.6        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         | EBI_AD6     | I/O  | MFP2  | EBI address/data bus bit 6.                   |
|        |         | SPI1_SS     | I/O  | MFP4  | SPI1 slave select pin.                        |
|        |         | SD1_nCD     | I    | MFP5  | SD/SDIO1 card detect input pin                |
|        |         | SC2_CLK     | O    | MFP6  | Smart Card 2 clock pin.                       |
|        |         | UART0_RXD   | I    | MFP7  | UART0 data receiver input pin.                |
|        |         | I2C1_SDA    | I/O  | MFP8  | I2C1 data input/output pin.                   |
|        |         | EPWM1_CH5   | I/O  | MFP11 | EPWM1 channel 5 output/capture input.         |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
| 22     | 52      | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 23     | 53      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 24     | 54      | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |
| 25     | 55      | PA.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | SPIM_D2         | I/O  | MFP2  | SPIM data 2 pin for Quad Mode I/O.                                              |
|        |         | QSPI0_MISO1     | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin.                                     |
|        |         | SPI1_I2SMCLK    | I/O  | MFP4  | SPI1 I2S master clock output pin                                                |
|        |         | SD1_CMD         | I/O  | MFP5  | SD/SDIO1 command/response pin                                                   |
|        |         | SC2_nCD         | I    | MFP6  | Smart Card 2 card detect pin.                                                   |
|        |         | UART0_nCTS      | I    | MFP7  | UART0 clear to Send input pin.                                                  |
|        |         | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.                                              |
|        |         | I2C0_SCL        | I/O  | MFP9  | I2C0 clock pin.                                                                 |
|        |         | CAN0_TXD        | O    | MFP10 | CAN0 bus transmitter output.                                                    |
|        |         | BPWM0_CH5       | I/O  | MFP12 | BPWM0 channel 5 output/capture input.                                           |
|        |         | EPWM0_CH0       | I/O  | MFP13 | EPWM0 channel 0 output/capture input.                                           |
|        |         | QEIO_INDEX      | I    | MFP14 | Quadrature encoder 0 index input                                                |
| 26     | 56      | PA.4            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | SPIM_D3         | I/O  | MFP2  | SPIM data 3 pin for Quad Mode I/O.                                              |
|        |         | QSPI0_MOSI1     | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin.                                     |
|        |         | SPI0_I2SMCLK    | I/O  | MFP4  | SPI0 I2S master clock output pin                                                |
|        |         | SD1_CLK         | O    | MFP5  | SD/SDIO1 clock output pin                                                       |
|        |         | SC0_nCD         | I    | MFP6  | Smart Card 0 card detect pin.                                                   |
|        |         | UART0_nRTS      | O    | MFP7  | UART0 request to Send output pin.                                               |
|        |         | UART5_RXD       | I    | MFP8  | UART5 data receiver input pin.                                                  |
|        |         | I2C0_SDA        | I/O  | MFP9  | I2C0 data input/output pin.                                                     |
|        |         | CAN0_RXD        | I    | MFP10 | CAN0 bus receiver input.                                                        |
|        |         | BPWM0_CH4       | I/O  | MFP12 | BPWM0 channel 4 output/capture input.                                           |
|        |         | EPWM0_CH1       | I/O  | MFP13 | EPWM0 channel 1 output/capture input.                                           |
|        |         | QEIO_A          | I    | MFP14 | Quadrature encoder 0 phase A input                                              |
| 27     | 57      | PA.3            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | SPIM_SS         | I/O  | MFP2  | SPIM slave select pin.                                                          |
|        |         | QSPI0_SS        | I/O  | MFP3  | Quad SPI0 slave select pin.                                                     |
|        |         | SPI0_SS         | I/O  | MFP4  | SPI0 slave select pin.                                                          |

| 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|---------|-------------|------|-------|---------------------------------------------|
|        |         | SD1_DAT3    | I/O  | MFP5  | SD/SDIO1 data line bit 3.                   |
|        |         | SC0_PWR     | O    | MFP6  | Smart Card 0 power pin.                     |
|        |         | UART4_TXD   | O    | MFP7  | UART4 data transmitter output pin.          |
|        |         | UART1_TXD   | O    | MFP8  | UART1 data transmitter output pin.          |
|        |         | I2C1_SCL    | I/O  | MFP9  | I2C1 clock pin.                             |
|        |         | BPWM0_CH3   | I/O  | MFP12 | BPWM0 channel 3 output/capture input.       |
|        |         | EPWM0_CH2   | I/O  | MFP13 | EPWM0 channel 2 output/capture input.       |
|        |         | QE10_B      | I    | MFP14 | Quadrature encoder 0 phase B input          |
|        |         | PA.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | SPI_M_CLK   | I/O  | MFP2  | SPI_M serial clock pin.                     |
|        |         | QSPI0_CLK   | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |         | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                      |
|        |         | SD1_DAT2    | I/O  | MFP5  | SD/SDIO1 data line bit 2.                   |
|        |         | SC0_RST     | O    | MFP6  | Smart Card 0 reset pin.                     |
|        |         | UART4_RXD   | I    | MFP7  | UART4 data receiver input pin.              |
|        |         | UART1_RXD   | I    | MFP8  | UART1 data receiver input pin.              |
|        |         | I2C1_SDA    | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |         | BPWM0_CH2   | I/O  | MFP12 | BPWM0 channel 2 output/capture input.       |
|        |         | EPWM0_CH3   | I/O  | MFP13 | EPWM0 channel 3 output/capture input.       |
|        |         | PA.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | SPI_M_MISO  | I/O  | MFP2  | SPI_M MISO (Master In, Slave Out) pin.      |
|        |         | QSPI0_MISO0 | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |         | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|        |         | SD1_DAT1    | I/O  | MFP5  | SD/SDIO1 data line bit 1.                   |
|        |         | SC0_DAT     | I/O  | MFP6  | Smart Card 0 data pin.                      |
|        |         | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.          |
|        |         | UART1_nCTS  | I    | MFP8  | UART1 clear to Send input pin.              |
|        |         | I2C2_SCL    | I/O  | MFP9  | I2C2 clock pin.                             |
|        |         | BPWM0_CH1   | I/O  | MFP12 | BPWM0 channel 1 output/capture input.       |
|        |         | EPWM0_CH4   | I/O  | MFP13 | EPWM0 channel 4 output/capture input.       |
|        |         | DAC1_ST     | I    | MFP15 | DAC1 external trigger input.                |
|        |         | PA.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | SPI_M_MOSI  | I/O  | MFP2  | SPI_M MOSI (Master Out, Slave In) pin.      |
|        |         | QSPI0_MOSI0 | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |

| 64 Pin | 128 Pin | Pin Name          | Type | MFP   | Description                                                                                          |
|--------|---------|-------------------|------|-------|------------------------------------------------------------------------------------------------------|
|        |         | SPI0_MOSI         | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.                                                                |
|        |         | SD1_DAT0          | I/O  | MFP5  | SD/SDIO1 data line bit 0.                                                                            |
|        |         | SC0_CLK           | O    | MFP6  | Smart Card 0 clock pin.                                                                              |
|        |         | UART0_RXD         | I    | MFP7  | UART0 data receiver input pin.                                                                       |
|        |         | UART1_nRTS        | O    | MFP8  | UART1 request to Send output pin.                                                                    |
|        |         | I2C2_SDA          | I/O  | MFP9  | I2C2 data input/output pin.                                                                          |
|        |         | BPWM0_CH0         | I/O  | MFP12 | BPWM0 channel 0 output/capture input.                                                                |
|        |         | EPWM0_CH5         | I/O  | MFP13 | EPWM0 channel 5 output/capture input.                                                                |
|        |         | DAC0_ST           | I    | MFP15 | DAC0 external trigger input.                                                                         |
| 31     | 61      | V <sub>DDIO</sub> | P    | MFP0  | Power supply for PA.0~PA.5.                                                                          |
|        | 62      | PE.14             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         | EBI_AD8           | I/O  | MFP2  | EBI address/data bus bit 8.                                                                          |
|        |         | UART2_TXD         | O    | MFP3  | UART2 data transmitter output pin.                                                                   |
|        |         | CAN0_TXD          | O    | MFP4  | CAN0 bus transmitter output.                                                                         |
|        |         | SD1_nCD           | I    | MFP5  | SD/SDIO1 card detect input pin                                                                       |
|        | 63      | PE.15             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         | EBI_AD9           | I/O  | MFP2  | EBI address/data bus bit 9.                                                                          |
|        |         | UART2_RXD         | I    | MFP3  | UART2 data receiver input pin.                                                                       |
|        |         | CAN0_RXD          | I    | MFP4  | CAN0 bus receiver input.                                                                             |
| 32     | 64      | nRESET            | I    | MFP0  | External reset input: active LOW, with an internal pull-up. Set this pin low reset to initial state. |
|        | 65      | PF.0              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         | UART1_TXD         | O    | MFP2  | UART1 data transmitter output pin.                                                                   |
|        |         | I2C1_SCL          | I/O  | MFP3  | I2C1 clock pin.                                                                                      |
|        |         | BPWM1_CH0         | I/O  | MFP12 | BPWM1 channel 0 output/capture input.                                                                |
|        |         | ICE_DAT           | O    | MFP14 | Serial wired debugger data pin.                                                                      |
|        | 66      | PF.1              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         | UART1_RXD         | I    | MFP2  | UART1 data receiver input pin.                                                                       |
|        |         | I2C1_SDA          | I/O  | MFP3  | I2C1 data input/output pin.                                                                          |
|        |         | BPWM1_CH1         | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                                                                |
|        |         | ICE_CLK           | I    | MFP14 | Serial wired debugger clock pin.                                                                     |
|        | 67      | PD.9              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         | EBI_AD7           | I/O  | MFP2  | EBI address/data bus bit 7.                                                                          |
|        |         | I2C2_SCL          | I/O  | MFP3  | I2C2 clock pin.                                                                                      |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|---------|--------------|------|-------|---------------------------------------------|
|        |         | UART2_nCTS   | I    | MFP4  | UART2 clear to Send input pin.              |
| 68     | 69      | PD.8         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD6      | I/O  | MFP2  | EBI address/data bus bit 6.                 |
|        |         | I2C2_SDA     | I/O  | MFP3  | I2C2 data input/output pin.                 |
|        |         | UART2_nRTS   | O    | MFP4  | UART2 request to Send output pin.           |
| 35     | 69      | PC.5         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD5      | I/O  | MFP2  | EBI address/data bus bit 5.                 |
|        |         | SPIM_D2      | I/O  | MFP3  | SPIM data 2 pin for Quad Mode I/O.          |
|        |         | QSPI0_MISO1  | I/O  | MFP4  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |         | UART2_TXD    | O    | MFP8  | UART2 data transmitter output pin.          |
|        |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |         | CAN0_TXD     | O    | MFP10 | CAN0 bus transmitter output.                |
|        |         | UART4_TXD    | O    | MFP11 | UART4 data transmitter output pin.          |
|        |         | EPWM1_CH0    | I/O  | MFP12 | EPWM1 channel 0 output/capture input.       |
|        |         | PC.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
| 36     | 70      | EBI_AD4      | I/O  | MFP2  | EBI address/data bus bit 4.                 |
|        |         | SPIM_D3      | I/O  | MFP3  | SPIM data 3 pin for Quad Mode I/O.          |
|        |         | QSPI0_MOSI1  | I/O  | MFP4  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |         | SC1_nCD      | I    | MFP5  | Smart Card 1 card detect pin.               |
|        |         | I2S0_BCLK    | O    | MFP6  | I2S0 bit clock output pin.                  |
|        |         | SPI1_I2SMCLK | I/O  | MFP7  | SPI1 I2S master clock output pin            |
|        |         | UART2_RXD    | I    | MFP8  | UART2 data receiver input pin.              |
|        |         | I2C1_SDA     | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |         | CAN0_RXD     | I    | MFP10 | CAN0 bus receiver input.                    |
|        |         | UART4_RXD    | I    | MFP11 | UART4 data receiver input pin.              |
|        |         | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        |         | PC.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
| 37     | 71      | EBI_AD3      | I/O  | MFP2  | EBI address/data bus bit 3.                 |
|        |         | SPIM_SS      | I/O  | MFP3  | SPIM slave select pin.                      |
|        |         | QSPI0_SS     | I/O  | MFP4  | Quad SPI0 slave select pin.                 |
|        |         | SC1_PWR      | O    | MFP5  | Smart Card 1 power pin.                     |
|        |         | I2S0_MCLK    | O    | MFP6  | I2S0 master clock output pin.               |
|        |         | SPI1_MISO    | I/O  | MFP7  | SPI1 MISO (Master In, Slave Out) pin.       |
|        |         | UART2_nRTS   | O    | MFP8  | UART2 request to Send output pin.           |

| 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|---------|-------------|------|-------|---------------------------------------------|
|        |         | I2C0_SMBAL  | O    | MFP9  | I2C0 SMBus SMBALTER pin                     |
|        |         | CAN1_TXD    | O    | MFP10 | CAN1 bus transmitter output.                |
|        |         | UART3_TXD   | O    | MFP11 | UART3 data transmitter output pin.          |
|        |         | EPWM1_CH2   | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        | 38      | PC.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD2     | I/O  | MFP2  | EBI address/data bus bit 2.                 |
|        |         | SPIM_CLK    | I/O  | MFP3  | SPIM serial clock pin.                      |
|        |         | QSPI0_CLK   | I/O  | MFP4  | Quad SPI0 serial clock pin.                 |
|        |         | SC1_RST     | O    | MFP5  | Smart Card 1 reset pin.                     |
|        |         | I2S0_DI     | I    | MFP6  | I2S0 data input pin.                        |
|        |         | SPI1_MOSI   | I/O  | MFP7  | SPI1 MOSI (Master Out, Slave In) pin.       |
|        |         | UART2_nCTS  | I    | MFP8  | UART2 clear to Send input pin.              |
|        |         | I2C0_SMBSUS | O    | MFP9  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |         | CAN1_RXD    | I    | MFP10 | CAN1 bus receiver input.                    |
|        |         | UART3_RXD   | I    | MFP11 | UART3 data receiver input pin.              |
|        |         | EPWM1_CH3   | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        | 39      | PC.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD1     | I/O  | MFP2  | EBI address/data bus bit 1.                 |
|        |         | SPIM_MISO   | I/O  | MFP3  | SPIM MISO (Master In, Slave Out) pin.       |
|        |         | QSPI0_MISO0 | I/O  | MFP4  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |         | SC1_DAT     | I/O  | MFP5  | Smart Card 1 data pin.                      |
|        |         | I2S0_DO     | O    | MFP6  | I2S0 data output pin.                       |
|        |         | SPI1_CLK    | I/O  | MFP7  | SPI1 serial clock pin.                      |
|        |         | UART2_TXD   | O    | MFP8  | UART2 data transmitter output pin.          |
|        |         | I2C0_SCL    | I/O  | MFP9  | I2C0 clock pin.                             |
|        |         | EPWM1_CH4   | I/O  | MFP12 | EPWM1 channel 4 output/capture input.       |
|        | 40      | ACMP0_O     | O    | MFP14 | Analog comparator 0 output pin.             |
|        |         | PC.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD0     | I/O  | MFP2  | EBI address/data bus bit 0.                 |
|        |         | SPIM_MOSI   | I/O  | MFP3  | SPIM MOSI (Master Out, Slave In) pin.       |
|        |         | QSPI0_MOSI0 | I/O  | MFP4  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|        |         | SC1_CLK     | O    | MFP5  | Smart Card 1 clock pin.                     |
|        |         | I2S0_LRCK   | O    | MFP6  | I2S0 left right channel clock output pin.   |
|        |         | SPI1_SS     | I/O  | MFP7  | SPI1 slave select pin.                      |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         | UART2_RXD       | I    | MFP8  | UART2 data receiver input pin.                                                  |
|        |         | I2C0_SDA        | I/O  | MFP9  | I2C0 data input/output pin.                                                     |
|        |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |         | ACMP1_O         | O    | MFP14 | Analog comparator 1 output pin.                                                 |
|        | 75      | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        | 76      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        | 77      | PG.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD0         | I/O  | MFP2  | EBI address/data bus bit 0.                                                     |
|        |         | SD1_DAT3        | I/O  | MFP3  | SD/SDIO1 data line bit 3.                                                       |
|        |         | SPI_M_D2        | I/O  | MFP4  | SPI_M data 2 pin for Quad Mode I/O.                                             |
|        |         | BPWM0_CH5       | I/O  | MFP12 | BPWM0 channel 5 output/capture input.                                           |
|        | 78      | PG.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD1         | I/O  | MFP2  | EBI address/data bus bit 1.                                                     |
|        |         | SD1_DAT2        | I/O  | MFP3  | SD/SDIO1 data line bit 2.                                                       |
|        |         | SPI_M_D3        | I/O  | MFP4  | SPI_M data 3 pin for Quad Mode I/O.                                             |
|        |         | BPWM0_CH4       | I/O  | MFP12 | BPWM0 channel 4 output/capture input.                                           |
|        | 79      | PG.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD2         | I/O  | MFP2  | EBI address/data bus bit 2.                                                     |
|        |         | SD1_DAT1        | I/O  | MFP3  | SD/SDIO1 data line bit 1.                                                       |
|        |         | SPI_M_SS        | I/O  | MFP4  | SPI_M slave select pin.                                                         |
|        |         | BPWM0_CH3       | I/O  | MFP12 | BPWM0 channel 3 output/capture input.                                           |
|        | 80      | PG.12           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD3         | I/O  | MFP2  | EBI address/data bus bit 3.                                                     |
|        |         | SD1_DAT0        | I/O  | MFP3  | SD/SDIO1 data line bit 0.                                                       |
|        |         | SPI_M_CLK       | I/O  | MFP4  | SPI_M serial clock pin.                                                         |
|        |         | BPWM0_CH2       | I/O  | MFP12 | BPWM0 channel 2 output/capture input.                                           |
|        | 81      | PG.13           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD4         | I/O  | MFP2  | EBI address/data bus bit 4.                                                     |
|        |         | SD1_CMD         | I/O  | MFP3  | SD/SDIO1 command/response pin                                                   |
|        |         | SPI_M_MISO      | I/O  | MFP4  | SPI_M MISO (Master In, Slave Out) pin.                                          |
|        |         | BPWM0_CH1       | I/O  | MFP12 | BPWM0 channel 1 output/capture input.                                           |
|        | 82      | PG.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD5         | I/O  | MFP2  | EBI address/data bus bit 5.                                                     |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|---------|--------------|------|-------|---------------------------------------|
|        |         | SD1_CLK      | O    | MFP3  | SD/SDIO1 clock output pin             |
|        |         | SPIM_MOSI    | I/O  | MFP4  | SPIM MOSI (Master Out, Slave In) pin. |
|        |         | BPWM0_CH0    | I/O  | MFP12 | BPWM0 channel 0 output/capture input. |
|        | 83      | PG.15        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | SD1_nCD      | I    | MFP3  | SD/SDIO1 card detect input pin        |
|        |         | CLKO         | O    | MFP14 | Clock Out                             |
|        |         | EADC0_ST     | I    | MFP15 | EADC0 external trigger input.         |
|        | 84      | PD.13        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_AD10     | I/O  | MFP2  | EBI address/data bus bit 10.          |
|        |         | SD0_nCD      | I    | MFP3  | SD/SDIO0 card detect input pin        |
|        |         | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin      |
|        |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin      |
|        |         | SC2_nCD      | I    | MFP7  | Smart Card 2 card detect pin.         |
|        | 85      | PA.12        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | I2S0_BCLK    | O    | MFP2  | I2S0 bit clock output pin.            |
|        |         | UART4_TXD    | O    | MFP3  | UART4 data transmitter output pin.    |
|        |         | I2C1_SCL     | I/O  | MFP4  | I2C1 clock pin.                       |
|        |         | SPI2_SS      | I/O  | MFP5  | SPI2 slave select pin.                |
|        |         | CAN0_TXD     | O    | MFP6  | CAN0 bus transmitter output.          |
|        |         | SC2_PWR      | O    | MFP7  | Smart Card 2 power pin.               |
|        |         | BPWM1_CH2    | I/O  | MFP11 | BPWM1 channel 2 output/capture input. |
|        |         | QEI1_INDEX   | I    | MFP12 | Quadrature encoder 1 index input      |
|        |         | USB_VBUS     | P    | MFP14 | Power supply from USB host or HUB.    |
|        | 86      | PA.13        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | I2S0_MCLK    | O    | MFP2  | I2S0 master clock output pin.         |
|        |         | UART4_RXD    | I    | MFP3  | UART4 data receiver input pin.        |
|        |         | I2C1_SDA     | I/O  | MFP4  | I2C1 data input/output pin.           |
|        |         | SPI2_CLK     | I/O  | MFP5  | SPI2 serial clock pin.                |
|        |         | CAN0_RXD     | I    | MFP6  | CAN0 bus receiver input.              |
|        |         | SC2_RST      | O    | MFP7  | Smart Card 2 reset pin.               |
|        |         | BPWM1_CH3    | I/O  | MFP11 | BPWM1 channel 3 output/capture input. |
|        |         | QEI1_A       | I    | MFP12 | Quadrature encoder 1 phase A input    |
|        |         | USB_D-       | A    | MFP14 | USB differential signal D-.           |
|        | 87      | PA.14        | I/O  | MFP0  | General purpose digital I/O pin.      |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                                                              |
|--------|---------|-----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------|
|        |         | I2S0_DI         | I    | MFP2  | I2S0 data input pin.                                                                                                     |
|        |         | UART0_TXD       | O    | MFP3  | UART0 data transmitter output pin.                                                                                       |
|        |         | SPI2_MISO       | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.                                                                                    |
|        |         | I2C2_SCL        | I/O  | MFP6  | I2C2 clock pin.                                                                                                          |
|        |         | SC2_DAT         | I/O  | MFP7  | Smart Card 2 data pin.                                                                                                   |
|        |         | BPWM1_CH4       | I/O  | MFP11 | BPWM1 channel 4 output/capture input.                                                                                    |
|        |         | QEI1_B          | I    | MFP12 | Quadrature encoder 1 phase B input                                                                                       |
|        |         | USB_D+          | A    | MFP14 | USB differential signal D+.                                                                                              |
|        | 88      | PA.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |         | I2S0_DO         | O    | MFP2  | I2S0 data output pin.                                                                                                    |
|        |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.                                                                                           |
|        |         | SPI2_MOSI       | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.                                                                                    |
|        |         | I2C2_SDA        | I/O  | MFP6  | I2C2 data input/output pin.                                                                                              |
|        |         | SC2_CLK         | O    | MFP7  | Smart Card 2 clock pin.                                                                                                  |
|        |         | BPWM1_CH5       | I/O  | MFP11 | BPWM1 channel 5 output/capture input.                                                                                    |
|        |         | EPWM0_SYNC_IN   | I    | MFP12 | EPWM0 counter synchronous trigger input pin.                                                                             |
|        |         | USB_OTG_ID      | I    | MFP14 | USB_ identification.                                                                                                     |
| 41     | 89      | HSUSB_VRES      | A    | MFP0  | HSUSB module reference resister                                                                                          |
| 42     | 90      | HSUSB_VDD33     | P    | MFP0  | Power supply for HSUSB VDD33                                                                                             |
| 43     | 91      | HSUSB_VBUS      | P    | MFP0  | HSUSB Power supply from USB host or HUB.                                                                                 |
| 44     | 92      | HSUSB_D-        | A    | MFP0  | HSUSB differential signal D-.                                                                                            |
| 45     | 93      | HSUSB_VSS       | P    | MFP0  | Ground pin for HSUSB.                                                                                                    |
| 46     | 94      | HSUSB_D+        | A    | MFP0  | HSUSB differential signal D+.                                                                                            |
| 47     | 95      | HSUSB_VDD12_CAP | A    | MFP0  | HSUSB Internal power regulator output 1.2V decoupling pin.<br>Note: This pin needs to be connected with a 1uF capacitor. |
| 48     | 96      | HSUSB_ID        | I    | MFP0  | HSUSB identification.                                                                                                    |
|        | 97      | PE.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                                                            |
|        |         | SPIM_D2         | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.                                                                                       |
|        |         | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.                                                                                       |
|        |         | CAN1_TXD        | O    | MFP9  | CAN1 bus transmitter output.                                                                                             |
|        |         | QEI1_INDEX      | I    | MFP11 | Quadrature encoder 1 index input                                                                                         |
|        |         | EPWM0_CH0       | I/O  | MFP12 | EPWM0 channel 0 output/capture input.                                                                                    |
|        |         | BPWM0_CH5       | I/O  | MFP13 | BPWM0 channel 5 output/capture input.                                                                                    |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|---------|--------------|------|-------|---------------------------------------|
|        | 98      | PE.6         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | SD0_CLK      | O    | MFP3  | SD/SDIO0 clock output pin             |
|        |         | SPIM_D3      | I/O  | MFP4  | SPIM data 3 pin for Quad Mode I/O.    |
|        |         | SPI3_I2SMCLK | I/O  | MFP5  | SPI3 I2S master clock output pin      |
|        |         | SC0_nCD      | I    | MFP6  | Smart Card 0 card detect pin.         |
|        |         | USCI0_CTL0   | I/O  | MFP7  | USCI0 control 0 pin.                  |
|        |         | UART5_RXD    | I    | MFP8  | UART5 data receiver input pin.        |
|        |         | CAN1_RXD     | I    | MFP9  | CAN1 bus receiver input.              |
|        |         | QEI1_A       | I    | MFP11 | Quadrature encoder 1 phase A input    |
|        |         | EPWM0_CH1    | I/O  | MFP12 | EPWM0 channel 1 output/capture input. |
|        | 99      | BPWM0_CH4    | I/O  | MFP13 | BPWM0 channel 4 output/capture input. |
|        |         | PE.5         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_nRD      | O    | MFP2  | EBI read enable output pin.           |
|        |         | SD0_DAT3     | I/O  | MFP3  | SD/SDIO0 data line bit 3.             |
|        |         | SPIM_SS      | I/O  | MFP4  | SPIM slave select pin.                |
|        |         | SPI3_SS      | I/O  | MFP5  | SPI3 slave select pin.                |
|        |         | SC0_PWR      | O    | MFP6  | Smart Card 0 power pin.               |
|        |         | USCI0_CTL1   | I/O  | MFP7  | USCI0 control 1 pin.                  |
|        |         | QEI1_B       | I    | MFP11 | Quadrature encoder 1 phase B input    |
|        |         | EPWM0_CH2    | I/O  | MFP12 | EPWM0 channel 2 output/capture input. |
|        | 100     | BPWM0_CH3    | I/O  | MFP13 | BPWM0 channel 3 output/capture input. |
|        |         | PE.4         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_nWR      | O    | MFP2  | EBI write enable output pin.          |
|        |         | SD0_DAT2     | I/O  | MFP3  | SD/SDIO0 data line bit 2.             |
|        |         | SPIM_CLK     | I/O  | MFP4  | SPIM serial clock pin.                |
|        |         | SPI3_CLK     | I/O  | MFP5  | SPI3 serial clock pin.                |
|        |         | SC0_RST      | O    | MFP6  | Smart Card 0 reset pin.               |
|        |         | USCI0_DAT1   | I/O  | MFP7  | USCI0 data 1 pin.                     |
|        |         | QEI0_INDEX   | I    | MFP11 | Quadrature encoder 0 index input      |
|        |         | EPWM0_CH3    | I/O  | MFP12 | EPWM0 channel 3 output/capture input. |
|        | 101     | BPWM0_CH2    | I/O  | MFP13 | BPWM0 channel 2 output/capture input. |
|        |         | PE.3         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         | EBI_MCLK     | O    | MFP2  | EBI external clock output pin.        |
|        |         | SD0_DAT1     | I/O  | MFP3  | SD/SDIO0 data line bit 1.             |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         | SPIM_MISO       | I/O  | MFP4  | SPIM MISO (Master In, Slave Out) pin.                                           |
|        |         | SPI3_MISO       | I/O  | MFP5  | SPI3 MISO (Master In, Slave Out) pin.                                           |
|        |         | SC0_DAT         | I/O  | MFP6  | Smart Card 0 data pin.                                                          |
|        |         | USCI0_DAT0      | I/O  | MFP7  | USCI0 data 0 pin.                                                               |
|        |         | QEI0_A          | I    | MFP11 | Quadrature encoder 0 phase A input                                              |
|        |         | EPWM0_CH4       | I/O  | MFP12 | EPWM0 channel 4 output/capture input.                                           |
|        |         | BPWM0_CH1       | I/O  | MFP13 | BPWM0 channel 1 output/capture input.                                           |
|        | 102     | PE.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_ALE         | O    | MFP2  | EBI address latch enable output pin.                                            |
|        |         | SD0_DAT0        | I/O  | MFP3  | SD/SDIO0 data line bit 0.                                                       |
|        |         | SPIM_MOSI       | I/O  | MFP4  | SPIM MOSI (Master Out, Slave In) pin.                                           |
|        |         | SPI3_MOSI       | I/O  | MFP5  | SPI3 MOSI (Master Out, Slave In) pin.                                           |
|        |         | SC0_CLK         | O    | MFP6  | Smart Card 0 clock pin.                                                         |
|        |         | USCI0_CLK       | I/O  | MFP7  | USCI0 clock pin.                                                                |
|        |         | QEI0_B          | I    | MFP11 | Quadrature encoder 0 phase B input                                              |
|        |         | EPWM0_CH5       | I/O  | MFP12 | EPWM0 channel 5 output/capture input.                                           |
|        |         | BPWM0_CH0       | I/O  | MFP13 | BPWM0 channel 0 output/capture input.                                           |
|        | 103     | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        | 104     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        | 105     | PE.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD10        | I/O  | MFP2  | EBI address/data bus bit 10.                                                    |
|        |         | QSPI0_MISO0     | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin.                                     |
|        |         | SC2_DAT         | I/O  | MFP4  | Smart Card 2 data pin.                                                          |
|        |         | I2S0_BCLK       | O    | MFP5  | I2S0 bit clock output pin.                                                      |
|        |         | SPI1_MISO       | I/O  | MFP6  | SPI1 MISO (Master In, Slave Out) pin.                                           |
|        |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |         | I2C1_SCL        | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |         | UART4_nCTS      | I    | MFP9  | UART4 clear to Send input pin.                                                  |
|        | 106     | PE.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |         | QSPI0_MOSI0     | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.                                     |
|        |         | SC2_CLK         | O    | MFP4  | Smart Card 2 clock pin.                                                         |
|        |         | I2S0_MCLK       | O    | MFP5  | I2S0 master clock output pin.                                                   |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|---------|--------------|------|-------|---------------------------------------------|
|        |         | SPI1_MOSI    | I/O  | MFP6  | SPI1 MOSI (Master Out, Slave In) pin.       |
|        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.              |
|        |         | I2C1_SDA     | I/O  | MFP8  | I2C1 data input/output pin.                 |
|        |         | UART4_nRTS   | O    | MFP9  | UART4 request to Send output pin.           |
|        | 107     | PH.8         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD12     | I/O  | MFP2  | EBI address/data bus bit 12.                |
|        |         | QSPI0_CLK    | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |         | SC2_PWR      | O    | MFP4  | Smart Card 2 power pin.                     |
|        |         | I2S0_DI      | I    | MFP5  | I2S0 data input pin.                        |
|        |         | SPI1_CLK     | I/O  | MFP6  | SPI1 serial clock pin.                      |
|        |         | UART3_nRTS   | O    | MFP7  | UART3 request to Send output pin.           |
|        |         | I2C1_SMBAL   | O    | MFP8  | I2C1 SMBus SMBALTER pin                     |
|        |         | I2C2_SCL     | I/O  | MFP9  | I2C2 clock pin.                             |
|        |         | UART1_TXD    | O    | MFP10 | UART1 data transmitter output pin.          |
|        | 108     | PH.9         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD13     | I/O  | MFP2  | EBI address/data bus bit 13.                |
|        |         | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                 |
|        |         | SC2_RST      | O    | MFP4  | Smart Card 2 reset pin.                     |
|        |         | I2S0_DO      | O    | MFP5  | I2S0 data output pin.                       |
|        |         | SPI1_SS      | I/O  | MFP6  | SPI1 slave select pin.                      |
|        |         | UART3_nCTS   | I    | MFP7  | UART3 clear to Send input pin.              |
|        |         | I2C1_SMBSUS  | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |         | I2C2_SDA     | I/O  | MFP9  | I2C2 data input/output pin.                 |
|        |         | UART1_RXD    | I    | MFP10 | UART1 data receiver input pin.              |
|        | 109     | PH.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD14     | I/O  | MFP2  | EBI address/data bus bit 14.                |
|        |         | QSPI0_MISO1  | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |         | SC2_nCD      | I    | MFP4  | Smart Card 2 card detect pin.               |
|        |         | I2S0_LRCK    | O    | MFP5  | I2S0 left right channel clock output pin.   |
|        |         | SPI1_I2SMCLK | I/O  | MFP6  | SPI1 I2S master clock output pin            |
|        |         | UART4_TXD    | O    | MFP7  | UART4 data transmitter output pin.          |
|        |         | UART0_TXD    | O    | MFP8  | UART0 data transmitter output pin.          |
|        | 110     | PH.11        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         | EBI_AD15     | I/O  | MFP2  | EBI address/data bus bit 15.                |

| 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         | QSPI0_MOSI1     | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin.                                     |
|        |         | UART4_RXD       | I    | MFP7  | UART4 data receiver input pin.                                                  |
|        |         | UART0_RXD       | I    | MFP8  | UART0 data receiver input pin.                                                  |
|        |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        | 111     | PD.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_nCS0        | O    | MFP2  | EBI chip select 0 output pin.                                                   |
|        |         | SPI3_I2SMCLK    | I/O  | MFP3  | SPI3 I2S master clock output pin                                                |
|        |         | SC1_nCD         | I    | MFP4  | Smart Card 1 card detect pin.                                                   |
|        |         | EPWM0_CH4       | I/O  | MFP11 | EPWM0 channel 4 output/capture input.                                           |
| 49     | 112     | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 50     | 113     | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |
| 51     | 114     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        | 115     | PC.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |         | SC1_nCD         | I    | MFP3  | Smart Card 1 card detect pin.                                                   |
|        |         | SPI0_I2SMCLK    | I/O  | MFP4  | SPI0 I2S master clock output pin                                                |
|        |         | USCI0_CTL0      | I/O  | MFP5  | USCI0 control 0 pin.                                                            |
|        |         | QSPI0_CLK       | I/O  | MFP6  | Quad SPI0 serial clock pin.                                                     |
|        |         | EPWM0_SYNC_IN   | I    | MFP11 | EPWM0 counter synchronous trigger input pin.                                    |
|        |         | TM1             | I/O  | MFP13 | Timer1 event counter input/toggle output pin.                                   |
|        |         | USB_VBUS_ST     | I    | MFP14 | USB external VBUS regulator status pin.                                         |
|        | 116     | HSUSB_VBUS_ST   | I    | MFP15 | HSUSB external VBUS regulator status pin.                                       |
|        |         | PB.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         | EADC0_CH15      | A    | MFP1  | EADC0 channel 15 analog input.                                                  |
|        |         | EBI_AD12        | I/O  | MFP2  | EBI address/data bus bit 12.                                                    |
|        |         | SC1_PWR         | O    | MFP3  | Smart Card 1 power pin.                                                         |
|        |         | SPI0_SS         | I/O  | MFP4  | SPI0 slave select pin.                                                          |
|        |         | USCI0_CTL1      | I/O  | MFP5  | USCI0 control 1 pin.                                                            |
|        |         | UART0_nCTS      | I    | MFP6  | UART0 clear to Send input pin.                                                  |
|        |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |         | I2C2_SMBAL      | O    | MFP8  | I2C2 SMBus SMBALTER pin                                                         |
|        |         | EPWM1_CH0       | I/O  | MFP11 | EPWM1 channel 0 output/capture input.                                           |
|        |         | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |

| 64 Pin | 128 Pin | Pin Name      | Type | MFP   | Description                                      |
|--------|---------|---------------|------|-------|--------------------------------------------------|
|        |         | USB_VBUS_EN   | O    | MFP14 | USB external VBUS regulator enable pin.          |
|        |         | HSUSB_VBUS_EN | O    | MFP15 | HSUSB external VBUS regulator enable pin.        |
| 54     | 117     | PB.14         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         | EADC0_CH14    | A    | MFP1  | EADC0 channel 14 analog input.                   |
|        |         | EBI_AD13      | I/O  | MFP2  | EBI address/data bus bit 13.                     |
|        |         | SC1_RST       | O    | MFP3  | Smart Card 1 reset pin.                          |
|        |         | SPI0_CLK      | I/O  | MFP4  | SPI0 serial clock pin.                           |
|        |         | USCI0_DAT1    | I/O  | MFP5  | USCI0 data 1 pin.                                |
|        |         | UART0_nRTS    | O    | MFP6  | UART0 request to Send output pin.                |
|        |         | UART3_RXD     | I    | MFP7  | UART3 data receiver input pin.                   |
|        |         | I2C2_SMBSUS   | O    | MFP8  | I2C2 SMBus SMBSUS pin (PMBus CONTROL pin)        |
|        |         | EPWM1_CH1     | I/O  | MFP11 | EPWM1 channel 1 output/capture input.            |
|        |         | TM1_EXT       | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |         | CLKO          | O    | MFP14 | Clock Out                                        |
| 55     | 118     | PB.13         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         | EADC0_CH13    | A    | MFP1  | EADC0 channel 13 analog input.                   |
|        |         | DAC1_OUT      | A    | MFP1  | DAC1 channel analog output.                      |
|        |         | ACMP0_P3      | A    | MFP1  | Analog comparator 0 positive input 3 pin.        |
|        |         | ACMP1_P3      | A    | MFP1  | Analog comparator 1 positive input 3 pin.        |
|        |         | EBI_AD14      | I/O  | MFP2  | EBI address/data bus bit 14.                     |
|        |         | SC1_DAT       | I/O  | MFP3  | Smart Card 1 data pin.                           |
|        |         | SPI0_MISO     | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.            |
|        |         | USCI0_DAT0    | I/O  | MFP5  | USCI0 data 0 pin.                                |
|        |         | UART0_TXD     | O    | MFP6  | UART0 data transmitter output pin.               |
|        |         | UART3_nRTS    | O    | MFP7  | UART3 request to Send output pin.                |
|        |         | I2C2_SCL      | I/O  | MFP8  | I2C2 clock pin.                                  |
|        |         | EPWM1_CH2     | I/O  | MFP11 | EPWM1 channel 2 output/capture input.            |
|        |         | TM2_EXT       | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
| 56     | 119     | PB.12         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         | EADC0_CH12    | A    | MFP1  | EADC0 channel 12 analog input.                   |
|        |         | DAC0_OUT      | A    | MFP1  | DAC0 channel analog output.                      |
|        |         | ACMP0_P2      | A    | MFP1  | Analog comparator 0 positive input 2 pin.        |
|        |         | ACMP1_P2      | A    | MFP1  | Analog comparator 1 positive input 2 pin.        |
|        |         | EBI_AD15      | I/O  | MFP2  | EBI address/data bus bit 15.                     |

| 64 Pin | 128 Pin | Pin Name         | Type | MFP   | Description                                                                                |
|--------|---------|------------------|------|-------|--------------------------------------------------------------------------------------------|
|        |         | SC1_CLK          | O    | MFP3  | Smart Card 1 clock pin.                                                                    |
|        |         | SPI0_MOSI        | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.                                                      |
|        |         | USCI0_CLK        | I/O  | MFP5  | USCI0 clock pin.                                                                           |
|        |         | UART0_RXD        | I    | MFP6  | UART0 data receiver input pin.                                                             |
|        |         | UART3_nCTS       | I    | MFP7  | UART3 clear to Send input pin.                                                             |
|        |         | I2C2_SDA         | I/O  | MFP8  | I2C2 data input/output pin.                                                                |
|        |         | SD0_nCD          | I    | MFP9  | SD/SDIO0 card detect input pin                                                             |
|        |         | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                                                      |
|        |         | TM3_EXT          | I/O  | MFP13 | Timer3 external capture input/toggle output pin.                                           |
| 57     | 120     | AV <sub>DD</sub> | P    | MFP0  | Power supply for internal analog circuit.                                                  |
| 58     | 121     | V <sub>REF</sub> | A    | MFP0  | ADC reference voltage input.<br>Note: This pin needs to be connected with a 1uF capacitor. |
| 59     | 122     | AV <sub>SS</sub> | P    | MFP0  | Ground pin for analog circuit.                                                             |
|        |         | PB.11            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |         | EADC0_CH11       | A    | MFP1  | EADC0 channel 11 analog input.                                                             |
|        |         | EBI_ADR16        | O    | MFP2  | EBI address bus bit 16.                                                                    |
|        |         | UART0_nCTS       | I    | MFP5  | UART0 clear to Send input pin.                                                             |
|        |         | UART4_TXD        | O    | MFP6  | UART4 data transmitter output pin.                                                         |
|        |         | I2C1_SCL         | I/O  | MFP7  | I2C1 clock pin.                                                                            |
|        |         | CAN0_TXD         | O    | MFP8  | CAN0 bus transmitter output.                                                               |
|        |         | SPI0_I2SMCLK     | I/O  | MFP9  | SPI0 I2S master clock output pin                                                           |
|        |         | BPWM1_CH0        | I/O  | MFP10 | BPWM1 channel 0 output/capture input.                                                      |
|        |         | SPI3_CLK         | I/O  | MFP11 | SPI3 serial clock pin.                                                                     |
|        |         | HSUSB_VBUS_ST    | I    | MFP14 | HSUSB external VBUS regulator status pin.                                                  |
|        |         | PB.10            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |         | EADC0_CH10       | A    | MFP1  | EADC0 channel 10 analog input.                                                             |
|        |         | EBI_ADR17        | O    | MFP2  | EBI address bus bit 17.                                                                    |
|        |         | USCI1_CTL0       | I/O  | MFP4  | USCI1 control 0 pin.                                                                       |
|        |         | UART0_nRTS       | O    | MFP5  | UART0 request to Send output pin.                                                          |
|        |         | UART4_RXD        | I    | MFP6  | UART4 data receiver input pin.                                                             |
|        |         | I2C1_SDA         | I/O  | MFP7  | I2C1 data input/output pin.                                                                |
|        |         | CAN0_RXD         | I    | MFP8  | CAN0 bus receiver input.                                                                   |
|        |         | BPWM1_CH1        | I/O  | MFP10 | BPWM1 channel 1 output/capture input.                                                      |
|        |         | SPI3_SS          | I/O  | MFP11 | SPI3 slave select pin.                                                                     |

| 64 Pin | 128 Pin | Pin Name      | Type | MFP   | Description                               |
|--------|---------|---------------|------|-------|-------------------------------------------|
|        |         | HSUSB_VBUS_EN | O    | MFP14 | HSUSB external VBUS regulator enable pin. |
| 62     | 125     | PB.9          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         | EADC0_CH9     | A    | MFP1  | EADC0 channel 9 analog input.             |
|        |         | EBI_ADR18     | O    | MFP2  | EBI address bus bit 18.                   |
|        |         | USCI1_CTL1    | I/O  | MFP4  | USCI1 control 1 pin.                      |
|        |         | UART0_TXD     | O    | MFP5  | UART0 data transmitter output pin.        |
|        |         | UART1_nCTS    | I    | MFP6  | UART1 clear to Send input pin.            |
|        |         | I2C1_SMBAL    | O    | MFP7  | I2C1 SMBus SMBALTER pin                   |
|        |         | BPWM1_CH2     | I/O  | MFP10 | BPWM1 channel 2 output/capture input.     |
|        |         | SPI3_MISO     | I/O  | MFP11 | SPI3 MISO (Master In, Slave Out) pin.     |
|        |         | INT7          | I    | MFP13 | External interrupt 7 input pin.           |
| 63     | 126     | PB.8          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         | EADC0_CH8     | A    | MFP1  | EADC0 channel 8 analog input.             |
|        |         | EBI_ADR19     | O    | MFP2  | EBI address bus bit 19.                   |
|        |         | USCI1_CLK     | I/O  | MFP4  | USCI1 clock pin.                          |
|        |         | UART0_RXD     | I    | MFP5  | UART0 data receiver input pin.            |
|        |         | UART1_nRTS    | O    | MFP6  | UART1 request to Send output pin.         |
|        |         | I2C1_SMBSUS   | O    | MFP7  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|        |         | BPWM1_CH3     | I/O  | MFP10 | BPWM1 channel 3 output/capture input.     |
|        |         | SPI3_MOSI     | I/O  | MFP11 | SPI3 MOSI (Master Out, Slave In) pin.     |
|        |         | INT6          | I    | MFP13 | External interrupt 6 input pin.           |
| 64     | 127     | PB.7          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         | EADC0_CH7     | A    | MFP1  | EADC0 channel 7 analog input.             |
|        |         | EBI_nWRL      | O    | MFP2  | EBI low byte write enable output pin.     |
|        |         | USCI1_DAT0    | I/O  | MFP4  | USCI1 data 0 pin.                         |
|        |         | CAN1_TXD      | O    | MFP5  | CAN1 bus transmitter output.              |
|        |         | UART1_TXD     | O    | MFP6  | UART1 data transmitter output pin.        |
|        |         | SD1_CMD       | I/O  | MFP7  | SD/SDIO1 command/response pin             |
|        |         | EBI_nCS0      | O    | MFP8  | EBI chip select 0 output pin.             |
|        |         | BPWM1_CH4     | I/O  | MFP10 | BPWM1 channel 4 output/capture input.     |
|        |         | EPWM1_BRAKE0  | I    | MFP11 | EPWM1 Brake 0 input pin.                  |
|        |         | EPWM1_CH4     | I/O  | MFP12 | EPWM1 channel 4 output/capture input.     |
|        |         | INT5          | I    | MFP13 | External interrupt 5 input pin.           |
|        |         | USB_VBUS_ST   | I    | MFP14 | USB external VBUS regulator status pin.   |

| 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                             |
|--------|---------|--------------|------|-------|-----------------------------------------|
|        |         | ACMP0_O      | O    | MFP15 | Analog comparator 0 output pin.         |
| 1      | 128     | PB.6         | I/O  | MFP0  | General purpose digital I/O pin.        |
|        |         | EADC0_CH6    | A    | MFP1  | EADC0 channel 6 analog input.           |
|        |         | EBI_nWRH     | O    | MFP2  | EBI high byte write enable output pin   |
|        |         | USCI1_DAT1   | I/O  | MFP4  | USCI1 data 1 pin.                       |
|        |         | CAN1_RXD     | I    | MFP5  | CAN1 bus receiver input.                |
|        |         | UART1_RXD    | I    | MFP6  | UART1 data receiver input pin.          |
|        |         | SD1_CLK      | O    | MFP7  | SD/SDIO1 clock output pin               |
|        |         | EBI_nCS1     | O    | MFP8  | EBI chip select 1 output pin.           |
|        |         | BPWM1_CH5    | I/O  | MFP10 | BPWM1 channel 5 output/capture input.   |
|        |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.                |
|        |         | EPWM1_CH5    | I/O  | MFP12 | EPWM1 channel 5 output/capture input.   |
|        |         | INT4         | I    | MFP13 | External interrupt 4 input pin.         |
|        |         | USB_VBUS_EN  | O    | MFP14 | USB external VBUS regulator enable pin. |
|        |         | ACMP1_O      | O    | MFP15 | Analog comparator 1 output pin.         |

#### 4.2.4 M484 Series Pin Description

64 Pin: M484SGAAE, M484SIDAE

64 Pin 2 USB: M484SGAAE2U, M484SIDAE2U

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|--------------|---------|------------|------|-------|-----------------------------------------------|
| 2      | 2            | 1       | PB.5       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EADC0_CH5  | A    | MFP1  | EADC0 channel 5 analog input.                 |
|        |              |         | ACMP1_N    | A    | MFP1  | Analog comparator 1 negative input pin.       |
|        |              |         | EBI_ADR0   | O    | MFP2  | EBI address bus bit 0.                        |
|        |              |         | SD0_DAT3   | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|        |              |         | SPI1_MISO  | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |              |         | I2C0_SCL   | I/O  | MFP6  | I2C0 clock pin.                               |
|        |              |         | UART5_TXD  | O    | MFP7  | UART5 data transmitter output pin.            |
|        |              |         | USCI1_CTL0 | I/O  | MFP8  | USCI1 control 0 pin.                          |
|        |              |         | SC0_CLK    | O    | MFP9  | Smart Card 0 clock pin.                       |
|        |              |         | I2S0_BCLK  | O    | MFP10 | I2S0 bit clock output pin.                    |
|        |              |         | EPWM0_CH0  | I/O  | MFP11 | EPWM0 channel 0 output/capture input.         |
|        |              |         | TM0        | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |              |         | INT0       | I    | MFP15 | External interrupt 0 input pin.               |
| 3      | 3            | 2       | PB.4       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EADC0_CH4  | A    | MFP1  | EADC0 channel 4 analog input.                 |
|        |              |         | ACMP1_P1   | A    | MFP1  | Analog comparator 1 positive input 1 pin.     |
|        |              |         | EBI_ADR1   | O    | MFP2  | EBI address bus bit 1.                        |
|        |              |         | SD0_DAT2   | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|        |              |         | SPI1_MOSI  | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |              |         | I2C0_SDA   | I/O  | MFP6  | I2C0 data input/output pin.                   |
|        |              |         | UART5_RXD  | I    | MFP7  | UART5 data receiver input pin.                |
|        |              |         | USCI1_CTL1 | I/O  | MFP8  | USCI1 control 1 pin.                          |
|        |              |         | SC0_DAT    | I/O  | MFP9  | Smart Card 0 data pin.                        |
|        |              |         | I2S0_MCLK  | O    | MFP10 | I2S0 master clock output pin.                 |
|        |              |         | EPWM0_CH1  | I/O  | MFP11 | EPWM0 channel 1 output/capture input.         |
|        |              |         | TM1        | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
|        |              |         | INT1       | I    | MFP15 | External interrupt 1 input pin.               |
| 4      | 4            | 3       | PB.3       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EADC0_CH3  | A    | MFP1  | EADC0 channel 3 analog input.                 |
|        |              |         | ACMP0_N    | A    | MFP1  | Analog comparator 0 negative input pin.       |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|--------------|---------|------------|------|-------|-----------------------------------------------|
|        |              |         | EBI_ADR2   | O    | MFP2  | EBI address bus bit 2.                        |
|        |              |         | SD0_DAT1   | I/O  | MFP3  | SD/SDIO0 data line bit 1.                     |
|        |              |         | SPI1_CLK   | I/O  | MFP5  | SPI1 serial clock pin.                        |
|        |              |         | UART1_TXD  | O    | MFP6  | UART1 data transmitter output pin.            |
|        |              |         | UART5_nRTS | O    | MFP7  | UART5 request to Send output pin.             |
|        |              |         | USCI1_DAT1 | I/O  | MFP8  | USCI1 data 1 pin.                             |
|        |              |         | SC0_RST    | O    | MFP9  | Smart Card 0 reset pin.                       |
|        |              |         | I2S0_DI    | I    | MFP10 | I2S0 data input pin.                          |
|        |              |         | EPWM0_CH2  | I/O  | MFP11 | EPWM0 channel 2 output/capture input.         |
|        |              |         | TM2        | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|        |              |         | INT2       | I    | MFP15 | External interrupt 2 input pin.               |
|        |              |         | PB.2       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EADC0_CH2  | A    | MFP1  | EADC0 channel 2 analog input.                 |
|        |              |         | ACMP0_P1   | A    | MFP1  | Analog comparator 0 positive input 1 pin.     |
|        |              |         | OPA0_O     | A    | MFP1  | Operational amplifier 0 output pin.           |
|        |              |         | EBI_ADR3   | O    | MFP2  | EBI address bus bit 3.                        |
|        |              |         | SD0_DAT0   | I/O  | MFP3  | SD/SDIO0 data line bit 0.                     |
|        |              |         | SPI1_SS    | I/O  | MFP5  | SPI1 slave select pin.                        |
|        |              |         | UART1_RXD  | I    | MFP6  | UART1 data receiver input pin.                |
|        |              |         | UART5_nCTS | I    | MFP7  | UART5 clear to Send input pin.                |
|        |              |         | USCI1_DAT0 | I/O  | MFP8  | USCI1 data 0 pin.                             |
|        |              |         | SC0_PWR    | O    | MFP9  | Smart Card 0 power pin.                       |
|        |              |         | I2S0_DO    | O    | MFP10 | I2S0 data output pin.                         |
|        |              |         | EPWM0_CH3  | I/O  | MFP11 | EPWM0 channel 3 output/capture input.         |
|        |              |         | TM3        | I/O  | MFP14 | Timer3 event counter input/toggle output pin. |
|        |              |         | INT3       | I    | MFP15 | External interrupt 3 input pin.               |
|        |              |         | PC.12      | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR4   | O    | MFP2  | EBI address bus bit 4.                        |
|        |              |         | UART0_TXD  | O    | MFP3  | UART0 data transmitter output pin.            |
|        |              |         | I2C0_SCL   | I/O  | MFP4  | I2C0 clock pin.                               |
|        |              |         | SPI3_MISO  | I/O  | MFP6  | SPI3 MISO (Master In, Slave Out) pin.         |
|        |              |         | SC0_nCD    | I    | MFP9  | Smart Card 0 card detect pin.                 |
|        |              |         | ECAP1_IC2  | I    | MFP11 | Enhanced capture unit 1 input 2 pin.          |
|        |              |         | EPWM1_CH0  | I/O  | MFP12 | EPWM1 channel 0 output/capture input.         |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name  | Type         | MFP   | Description                           |                                             |
|--------|--------------|---------|-----------|--------------|-------|---------------------------------------|---------------------------------------------|
|        |              |         | ACMP0_O   | O            | MFP14 | Analog comparator 0 output pin.       |                                             |
|        |              | 6       | PC.11     | I/O          | MFP0  | General purpose digital I/O pin.      |                                             |
|        |              |         | EBI_ADR5  | O            | MFP2  | EBI address bus bit 5.                |                                             |
|        |              |         | UART0_RXD | I            | MFP3  | UART0 data receiver input pin.        |                                             |
|        |              |         | I2C0_SDA  | I/O          | MFP4  | I2C0 data input/output pin.           |                                             |
|        |              |         | SPI3_MOSI | I/O          | MFP6  | SPI3 MOSI (Master Out, Slave In) pin. |                                             |
|        |              |         | ECAP1_IC1 | I            | MFP11 | Enhanced capture unit 1 input 1 pin.  |                                             |
|        |              |         | EPWM1_CH1 | I/O          | MFP12 | EPWM1 channel 1 output/capture input. |                                             |
|        |              |         | ACMP1_O   | O            | MFP14 | Analog comparator 1 output pin.       |                                             |
|        |              | 7       | PC.10     | I/O          | MFP0  | General purpose digital I/O pin.      |                                             |
|        |              |         | EBI_ADR6  | O            | MFP2  | EBI address bus bit 6.                |                                             |
|        |              |         | SPI3_CLK  | I/O          | MFP6  | SPI3 serial clock pin.                |                                             |
|        |              |         | UART3_TXD | O            | MFP7  | UART3 data transmitter output pin.    |                                             |
|        |              |         | ECAP1_IC0 | I            | MFP11 | Enhanced capture unit 1 input 0 pin.  |                                             |
|        |              |         | EPWM1_CH2 | I/O          | MFP12 | EPWM1 channel 2 output/capture input. |                                             |
|        |              | 8       | PC.9      | I/O          | MFP0  | General purpose digital I/O pin.      |                                             |
|        |              |         | EBI_ADR7  | O            | MFP2  | EBI address bus bit 7.                |                                             |
|        |              |         | SPI3_SS   | I/O          | MFP6  | SPI3 slave select pin.                |                                             |
|        |              |         | UART3_RXD | I            | MFP7  | UART3 data receiver input pin.        |                                             |
|        |              |         | EPWM1_CH3 | I/O          | MFP12 | EPWM1 channel 3 output/capture input. |                                             |
|        | 6            | 6       | 9         | PB.1         | I/O   | MFP0                                  | General purpose digital I/O pin.            |
|        |              |         |           | EADC0_CH1    | A     | MFP1                                  | EADC0 channel 1 analog input.               |
|        |              |         |           | OPA0_N       | A     | MFP1                                  | Operational amplifier 0 negative input pin. |
|        |              |         |           | EBI_ADR8     | O     | MFP2                                  | EBI address bus bit 8.                      |
|        |              |         |           | SD0_CLK      | O     | MFP3                                  | SD/SDIO0 clock output pin                   |
|        |              |         |           | SPI1_I2SMCLK | I/O   | MFP5                                  | SPI1 I2S master clock output pin            |
|        |              |         |           | SPI3_I2SMCLK | I/O   | MFP6                                  | SPI3 I2S master clock output pin            |
|        |              |         |           | UART2_TXD    | O     | MFP7                                  | UART2 data transmitter output pin.          |
|        |              |         |           | USCI1_CLK    | I/O   | MFP8                                  | USCI1 clock pin.                            |
|        |              |         |           | I2C1_SCL     | I/O   | MFP9                                  | I2C1 clock pin.                             |
|        |              |         |           | I2S0_LRCK    | O     | MFP10                                 | I2S0 left right channel clock output pin.   |
|        |              |         |           | EPWM0_CH4    | I/O   | MFP11                                 | EPWM0 channel 4 output/capture input.       |
|        |              |         |           | EPWM1_CH4    | I/O   | MFP12                                 | EPWM1 channel 4 output/capture input.       |
|        |              |         |           | EPWM0_BRAKE0 | I     | MFP13                                 | EPWM0 Brake 0 input pin.                    |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
| 7      | 7            | 10      | PB.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EADC0_CH0       | A    | MFP1  | EADC0 channel 0 analog input.                                                   |
|        |              |         | OPA0_P          | A    | MFP1  | Operational amplifier 0 positive input pin.                                     |
|        |              |         | EBI_ADR9        | O    | MFP2  | EBI address bus bit 9.                                                          |
|        |              |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                   |
|        |              |         | UART2_RXD       | I    | MFP7  | UART2 data receiver input pin.                                                  |
|        |              |         | SPI0_I2SMCLK    | I/O  | MFP8  | SPI0 I2S master clock output pin                                                |
|        |              |         | I2C1_SDA        | I/O  | MFP9  | I2C1 data input/output pin.                                                     |
|        |              |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |              |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |              |         | EPWM0_BRAKE1    | I    | MFP13 | EPWM0 Brake 1 input pin.                                                        |
|        |              | 11      | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |              | 12      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 8      | 8            | 13      | PA.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | ACMP0_P0        | A    | MFP1  | Analog comparator 0 positive input 0 pin.                                       |
|        |              |         | EBI_nRD         | O    | MFP2  | EBI read enable output pin.                                                     |
|        |              |         | SC2_PWR         | O    | MFP3  | Smart Card 2 power pin.                                                         |
|        |              |         | SPI2_SS         | I/O  | MFP4  | SPI2 slave select pin.                                                          |
|        |              |         | SD1_DAT3        | I/O  | MFP5  | SD/SDIO1 data line bit 3.                                                       |
|        |              |         | USCI0_CLK       | I/O  | MFP6  | USCI0 clock pin.                                                                |
|        |              |         | I2C2_SCL        | I/O  | MFP7  | I2C2 clock pin.                                                                 |
|        |              |         | BPWM0_CH0       | I/O  | MFP9  | BPWM0 channel 0 output/capture input.                                           |
|        |              |         | EPWM0_SYNC_OUT  | O    | MFP10 | EPWM0 counter synchronous trigger output pin.                                   |
| 9      | 9            | 14      | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
|        |              |         | DAC1_ST         | I    | MFP14 | DAC1 external trigger input.                                                    |
|        |              |         | PA.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | ACMP1_P0        | A    | MFP1  | Analog comparator 1 positive input 0 pin.                                       |
|        |              |         | OPA1_O          | A    | MFP1  | Operational amplifier 1 output pin.                                             |
|        |              |         | EBI_nWR         | O    | MFP2  | EBI write enable output pin.                                                    |
|        |              |         | SC2_RST         | O    | MFP3  | Smart Card 2 reset pin.                                                         |
|        |              |         | SPI2_CLK        | I/O  | MFP4  | SPI2 serial clock pin.                                                          |
|        |              |         | SD1_DAT2        | I/O  | MFP5  | SD/SDIO1 data line bit 2.                                                       |
|        |              |         | USCI0_DAT0      | I/O  | MFP6  | USCI0 data 0 pin.                                                               |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name   | Type | MFP   | Description                                      |
|--------|--------------|---------|------------|------|-------|--------------------------------------------------|
|        |              |         | I2C2_SDA   | I/O  | MFP7  | I2C2 data input/output pin.                      |
|        |              |         | BPWM0_CH1  | I/O  | MFP9  | BPWM0 channel 1 output/capture input.            |
|        |              |         | QEI1_INDEX | I    | MFP10 | Quadrature encoder 1 index input                 |
|        |              |         | ECAPO_IC0  | I    | MFP11 | Enhanced capture unit 0 input 0 pin.             |
|        |              |         | TM1_EXT    | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |              |         | DAC0_ST    | I    | MFP14 | DAC0 external trigger input.                     |
|        |              | 15      | PA.9       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |              |         | OPA1_N     | A    | MFP1  | Operational amplifier 1 negative input pin.      |
|        |              |         | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.                   |
|        |              |         | SC2_DAT    | I/O  | MFP3  | Smart Card 2 data pin.                           |
|        |              |         | SPI2_MISO  | I/O  | MFP4  | SPI2 MISO (Master In, Slave Out) pin.            |
|        |              |         | SD1_DAT1   | I/O  | MFP5  | SD/SDIO1 data line bit 1.                        |
|        |              |         | USCI0_DAT1 | I/O  | MFP6  | USCI0 data 1 pin.                                |
|        |              |         | UART1_TXD  | O    | MFP7  | UART1 data transmitter output pin.               |
|        |              |         | BPWM0_CH2  | I/O  | MFP9  | BPWM0 channel 2 output/capture input.            |
|        |              |         | QEI1_A     | I    | MFP10 | Quadrature encoder 1 phase A input               |
|        |              |         | ECAPO_IC1  | I    | MFP11 | Enhanced capture unit 0 input 1 pin.             |
|        |              |         | TM2_EXT    | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|        |              | 16      | PA.8       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |              |         | OPA1_P     | A    | MFP1  | Operational amplifier 1 positive input pin.      |
|        |              |         | EBI_ALE    | O    | MFP2  | EBI address latch enable output pin.             |
|        |              |         | SC2_CLK    | O    | MFP3  | Smart Card 2 clock pin.                          |
|        |              |         | SPI2_MOSI  | I/O  | MFP4  | SPI2 MOSI (Master Out, Slave In) pin.            |
|        |              |         | SD1_DAT0   | I/O  | MFP5  | SD/SDIO1 data line bit 0.                        |
|        |              |         | USCI0_CTL1 | I/O  | MFP6  | USCI0 control 1 pin.                             |
|        |              |         | UART1_RXD  | I    | MFP7  | UART1 data receiver input pin.                   |
|        |              |         | BPWM0_CH3  | I/O  | MFP9  | BPWM0 channel 3 output/capture input.            |
|        |              |         | QEI1_B     | I    | MFP10 | Quadrature encoder 1 phase B input               |
|        |              |         | ECAPO_IC2  | I    | MFP11 | Enhanced capture unit 0 input 2 pin.             |
|        |              |         | TM3_EXT    | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
|        |              |         | INT4       | I    | MFP15 | External interrupt 4 input pin.                  |
|        |              | 17      | PC.13      | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |              |         | EBI_ADR10  | O    | MFP2  | EBI address bus bit 10.                          |
|        |              |         | SC2_nCD    | I    | MFP3  | Smart Card 2 card detect pin.                    |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------------|---------|--------------|------|-------|-----------------------------------------------|
|        |              |         | SPI2_I2SMCLK | I/O  | MFP4  | SPI2 I2S master clock output pin              |
|        |              |         | USCI0_CTL0   | I/O  | MFP6  | USCI0 control 0 pin.                          |
|        |              |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.            |
|        |              |         | BPWM0_CH4    | I/O  | MFP9  | BPWM0 channel 4 output/capture input.         |
|        |              |         | CLKO         | O    | MFP13 | Clock Out                                     |
|        |              |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.                 |
|        |              | 18      | PD.12        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | OPA2_O       | A    | MFP1  | Operational amplifier 2 output pin.           |
|        |              |         | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.                 |
|        |              |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.                |
|        |              |         | BPWM0_CH5    | I/O  | MFP9  | BPWM0 channel 5 output/capture input.         |
|        |              |         | QEIO_INDEX   | I    | MFP10 | Quadrature encoder 0 index input              |
|        |              |         | CLKO         | O    | MFP13 | Clock Out                                     |
|        |              |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.                 |
|        |              |         | INT5         | I    | MFP15 | External interrupt 5 input pin.               |
|        |              | 19      | PD.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | OPA2_N       | A    | MFP1  | Operational amplifier 2 negative input pin.   |
|        |              |         | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.                 |
|        |              |         | UART1_TXD    | O    | MFP3  | UART1 data transmitter output pin.            |
|        |              |         | QEIO_A       | I    | MFP10 | Quadrature encoder 0 phase A input            |
|        |              |         | INT6         | I    | MFP15 | External interrupt 6 input pin.               |
|        |              | 20      | PD.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | OPA2_P       | A    | MFP1  | Operational amplifier 2 positive input pin.   |
|        |              |         | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.                 |
|        |              |         | UART1_RXD    | I    | MFP3  | UART1 data receiver input pin.                |
|        |              |         | QEIO_B       | I    | MFP10 | Quadrature encoder 0 phase B input            |
|        |              |         | INT7         | I    | MFP15 | External interrupt 7 input pin.               |
|        |              | 21      | PG.2         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.                       |
|        |              |         | SPI2_SS      | I/O  | MFP3  | SPI2 slave select pin.                        |
|        |              |         | I2C0_SMBAL   | O    | MFP4  | I2C0 SMBus SMBALTER pin                       |
|        |              |         | I2C1_SCL     | I/O  | MFP5  | I2C1 clock pin.                               |
|        |              |         | TM0          | I/O  | MFP13 | Timer0 event counter input/toggle output pin. |
|        |              | 22      | PG.3         | I/O  | MFP0  | General purpose digital I/O pin.              |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------------|---------|--------------|------|-------|-----------------------------------------------|
|        |              |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.                       |
|        |              |         | SPI2_CLK     | I/O  | MFP3  | SPI2 serial clock pin.                        |
|        |              |         | I2C0_SMBSUS  | O    | MFP4  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)     |
|        |              |         | I2C1_SDA     | I/O  | MFP5  | I2C1 data input/output pin.                   |
|        |              |         | TM1          | I/O  | MFP13 | Timer1 event counter input/toggle output pin. |
|        |              | 23      | PG.4         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.                       |
|        |              |         | SPI2_MISO    | I/O  | MFP3  | SPI2 MISO (Master In, Slave Out) pin.         |
|        |              |         | TM2          | I/O  | MFP13 | Timer2 event counter input/toggle output pin. |
|        |              | 24      | PF.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.                       |
|        |              |         | SPI2_MOSI    | I/O  | MFP3  | SPI2 MOSI (Master Out, Slave In) pin.         |
|        |              |         | TAMPER5      | I/O  | MFP10 | TAMPER detector loop pin 5.                   |
|        |              |         | TM3          | I/O  | MFP13 | Timer3 event counter input/toggle output pin. |
|        |              | 25      | PF.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |              |         | SC0_nCD      | I    | MFP3  | Smart Card 0 card detect pin.                 |
|        |              |         | I2S0_BCLK    | O    | MFP4  | I2S0 bit clock output pin.                    |
|        |              |         | SPI0_I2SMCLK | I/O  | MFP5  | SPI0 I2S master clock output pin              |
|        |              |         | TAMPER4      | I/O  | MFP10 | TAMPER detector loop pin 4.                   |
|        |              | 26      | PF.9         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |              |         | SC0_PWR      | O    | MFP3  | Smart Card 0 power pin.                       |
|        |              |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.                 |
|        |              |         | SPI0_SS      | I/O  | MFP5  | SPI0 slave select pin.                        |
|        |              |         | TAMPER3      | I/O  | MFP10 | TAMPER detector loop pin 3.                   |
|        |              | 27      | PF.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR17    | O    | MFP2  | EBI address bus bit 17.                       |
|        |              |         | SC0_RST      | O    | MFP3  | Smart Card 0 reset pin.                       |
|        |              |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                          |
|        |              |         | SPI0_CLK     | I/O  | MFP5  | SPI0 serial clock pin.                        |
|        |              |         | TAMPER2      | I/O  | MFP10 | TAMPER detector loop pin 2.                   |
|        |              | 28      | PF.7         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR18    | O    | MFP2  | EBI address bus bit 18.                       |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |              |         | SC0_DAT         | I/O  | MFP3  | Smart Card 0 data pin.                                                          |
|        |              |         | I2S0_DO         | O    | MFP4  | I2S0 data output pin.                                                           |
|        |              |         | SPI0_MISO       | I/O  | MFP5  | SPI0 MISO (Master In, Slave Out) pin.                                           |
|        |              |         | UART4_TXD       | O    | MFP6  | UART4 data transmitter output pin.                                              |
|        |              |         | TAMPER1         | I/O  | MFP10 | TAMPER detector loop pin 1.                                                     |
| 12     | 12           | 29      | PF.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_ADR19       | O    | MFP2  | EBI address bus bit 19.                                                         |
|        |              |         | SC0_CLK         | O    | MFP3  | Smart Card 0 clock pin.                                                         |
|        |              |         | I2S0_LRCK       | O    | MFP4  | I2S0 left right channel clock output pin.                                       |
|        |              |         | SPI0_MOSI       | I/O  | MFP5  | SPI0 MOSI (Master Out, Slave In) pin.                                           |
|        |              |         | UART4_RXD       | I    | MFP6  | UART4 data receiver input pin.                                                  |
|        |              |         | EBI_nCS0        | O    | MFP7  | EBI chip select 0 output pin.                                                   |
|        |              |         | TAMPER0         | I/O  | MFP10 | TAMPER detector loop pin 0.                                                     |
| 13     | 13           | 30      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 14     | 14           | 31      | PF.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | UART2_RXD       | I    | MFP2  | UART2 data receiver input pin.                                                  |
|        |              |         | UART2_nCTS      | I    | MFP4  | UART2 clear to Send input pin.                                                  |
|        |              |         | BPWM0_CH4       | I/O  | MFP8  | BPWM0 channel 4 output/capture input.                                           |
|        |              |         | EPWM0_SYNC_OUT  | O    | MFP9  | EPWM0 counter synchronous trigger output pin.                                   |
|        |              |         | X32_IN          | I    | MFP10 | External 32.768 kHz crystal input pin.                                          |
|        |              |         | EADC0_ST        | I    | MFP11 | EADC0 external trigger input.                                                   |
| 15     | 15           | 32      | PF.4            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | UART2_TXD       | O    | MFP2  | UART2 data transmitter output pin.                                              |
|        |              |         | UART2_nRTS      | O    | MFP4  | UART2 request to Send output pin.                                               |
|        |              |         | BPWM0_CH5       | I/O  | MFP8  | BPWM0 channel 5 output/capture input.                                           |
|        |              |         | X32_OUT         | O    | MFP10 | External 32.768 kHz crystal output pin.                                         |
|        |              | 33      | PH.4            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_ADR3        | O    | MFP2  | EBI address bus bit 3.                                                          |
|        |              |         | SPI1_MISO       | I/O  | MFP3  | SPI1 MISO (Master In, Slave Out) pin.                                           |
|        |              | 34      | PH.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_ADR2        | O    | MFP2  | EBI address bus bit 2.                                                          |
|        |              |         | SPI1_MOSI       | I/O  | MFP3  | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|        |              | 35      | PH.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |              |         | EBI_ADR1        | O    | MFP2  | EBI address bus bit 1.                                                          |
|        |              |         | SPI1_CLK        | I/O  | MFP3  | SPI1 serial clock pin.                                                          |
|        |              | 36      | PH.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_ADR0        | O    | MFP2  | EBI address bus bit 0.                                                          |
|        |              |         | SPI1_SS         | I/O  | MFP3  | SPI1 slave select pin.                                                          |
| 16     | 16           | 37      | PF.3            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_nCS0        | O    | MFP2  | EBI chip select 0 output pin.                                                   |
|        |              |         | UART0_TXD       | O    | MFP3  | UART0 data transmitter output pin.                                              |
|        |              |         | I2C0_SCL        | I/O  | MFP4  | I2C0 clock pin.                                                                 |
|        |              |         | XT1_IN          | I    | MFP10 | External 4~24 MHz (high speed) crystal input pin.                               |
|        |              |         | BPWM1_CH0       | I/O  | MFP11 | BPWM1 channel 0 output/capture input.                                           |
| 17     | 17           | 38      | PF.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_nCS1        | O    | MFP2  | EBI chip select 1 output pin.                                                   |
|        |              |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.                                                  |
|        |              |         | I2C0_SDA        | I/O  | MFP4  | I2C0 data input/output pin.                                                     |
|        |              |         | QSPI0_CLK       | I/O  | MFP5  | Quad SPI0 serial clock pin.                                                     |
|        |              |         | XT1_OUT         | O    | MFP10 | External 4~24 MHz (high speed) crystal output pin.                              |
|        |              |         | BPWM1_CH1       | I/O  | MFP11 | BPWM1 channel 1 output/capture input.                                           |
|        |              | 39      | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |              | 40      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |              | 41      | PE.8            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_ADR10       | O    | MFP2  | EBI address bus bit 10.                                                         |
|        |              |         | I2S0_BCLK       | O    | MFP4  | I2S0 bit clock output pin.                                                      |
|        |              |         | SPI2_CLK        | I/O  | MFP5  | SPI2 serial clock pin.                                                          |
|        |              |         | USCI1_CTL1      | I/O  | MFP6  | USCI1 control 1 pin.                                                            |
|        |              |         | UART2_TXD       | O    | MFP7  | UART2 data transmitter output pin.                                              |
|        |              |         | EPWM0_CH0       | I/O  | MFP10 | EPWM0 channel 0 output/capture input.                                           |
|        |              |         | EPWM0_BRAKE0    | I    | MFP11 | EPWM0 Brake 0 input pin.                                                        |
|        |              |         | ECAPO_IC0       | I    | MFP12 | Enhanced capture unit 0 input 0 pin.                                            |
|        |              |         | TRACE_CLK       | O    | MFP14 | ETM Trace Clock output pin                                                      |
|        |              | 42      | PE.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_ADR11       | O    | MFP2  | EBI address bus bit 11.                                                         |
|        |              |         | I2S0_MCLK       | O    | MFP4  | I2S0 master clock output pin.                                                   |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name     | Type | MFP   | Description                               |
|--------|--------------|---------|--------------|------|-------|-------------------------------------------|
|        |              |         | SPI2_MISO    | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.     |
|        |              |         | USCI1_CTL0   | I/O  | MFP6  | USCI1 control 0 pin.                      |
|        |              |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.            |
|        |              |         | EPWM0_CH1    | I/O  | MFP10 | EPWM0 channel 1 output/capture input.     |
|        |              |         | EPWM0_BRAKE1 | I    | MFP11 | EPWM0 Brake 1 input pin.                  |
|        |              |         | ECAPO_IC1    | I    | MFP12 | Enhanced capture unit 0 input 1 pin.      |
|        |              |         | TRACE_DATA0  | O    | MFP14 | ETM Trace Data 0 output pin               |
|        |              | 43      | PE.10        | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.                   |
|        |              |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                      |
|        |              |         | SPI2_MOSI    | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.     |
|        |              |         | USCI1_DAT0   | I/O  | MFP6  | USCI1 data 0 pin.                         |
|        |              |         | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.        |
|        |              |         | EPWM0_CH2    | I/O  | MFP10 | EPWM0 channel 2 output/capture input.     |
|        |              |         | EPWM1_BRAKE0 | I    | MFP11 | EPWM1 Brake 0 input pin.                  |
|        |              |         | ECAPO_IC2    | I    | MFP12 | Enhanced capture unit 0 input 2 pin.      |
|        |              |         | TRACE_DATA1  | O    | MFP14 | ETM Trace Data 1 output pin               |
|        |              | 44      | PE.11        | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.                   |
|        |              |         | I2S0_DO      | O    | MFP4  | I2S0 data output pin.                     |
|        |              |         | SPI2_SS      | I/O  | MFP5  | SPI2 slave select pin.                    |
|        |              |         | USCI1_DAT1   | I/O  | MFP6  | USCI1 data 1 pin.                         |
|        |              |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.            |
|        |              |         | UART1_nCTS   | I    | MFP8  | UART1 clear to Send input pin.            |
|        |              |         | EPWM0_CH3    | I/O  | MFP10 | EPWM0 channel 3 output/capture input.     |
|        |              |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.                  |
|        |              |         | ECAPO_IC2    | I    | MFP13 | Enhanced capture unit 1 input 2 pin.      |
|        |              | 45      | TRACE_DATA2  | O    | MFP14 | ETM Trace Data 2 output pin               |
|        |              |         | PE.12        | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.                   |
|        |              |         | I2S0_LRCK    | O    | MFP4  | I2S0 left right channel clock output pin. |
|        |              |         | SPI2_I2SMCLK | I/O  | MFP5  | SPI2 I2S master clock output pin          |
|        |              |         | USCI1_CLK    | I/O  | MFP6  | USCI1 clock pin.                          |
|        |              |         | UART1_nRTS   | O    | MFP8  | UART1 request to Send output pin.         |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name    | Type | MFP   | Description                                   |
|--------|--------------|---------|-------------|------|-------|-----------------------------------------------|
|        |              |         | EPWM0_CH4   | I/O  | MFP10 | EPWM0 channel 4 output/capture input.         |
|        |              |         | ECAP1_IC1   | I    | MFP13 | Enhanced capture unit 1 input 1 pin.          |
|        |              |         | TRACE_DATA3 | O    | MFP14 | ETM Trace Data 3 output pin                   |
|        |              | 46      | PE.13       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR15   | O    | MFP2  | EBI address bus bit 15.                       |
|        |              |         | I2C0_SCL    | I/O  | MFP4  | I2C0 clock pin.                               |
|        |              |         | UART4_nRTS  | O    | MFP5  | UART4 request to Send output pin.             |
|        |              |         | UART1_TXD   | O    | MFP8  | UART1 data transmitter output pin.            |
|        |              |         | EPWM0_CH5   | I/O  | MFP10 | EPWM0 channel 5 output/capture input.         |
|        |              |         | EPWM1_CH0   | I/O  | MFP11 | EPWM1 channel 0 output/capture input.         |
|        |              |         | BPWM1_CH5   | I/O  | MFP12 | BPWM1 channel 5 output/capture input.         |
|        |              |         | ECAP1_IC0   | I    | MFP13 | Enhanced capture unit 1 input 0 pin.          |
|        |              | 47      | PC.8        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_ADR16   | O    | MFP2  | EBI address bus bit 16.                       |
|        |              |         | I2C0_SDA    | I/O  | MFP4  | I2C0 data input/output pin.                   |
|        |              |         | UART4_nCTS  | I    | MFP5  | UART4 clear to Send input pin.                |
|        |              |         | UART1_RXD   | I    | MFP8  | UART1 data receiver input pin.                |
|        |              |         | EPWM1_CH1   | I/O  | MFP11 | EPWM1 channel 1 output/capture input.         |
|        |              |         | BPWM1_CH4   | I/O  | MFP12 | BPWM1 channel 4 output/capture input.         |
|        |              | 48      | PC.7        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_AD9     | I/O  | MFP2  | EBI address/data bus bit 9.                   |
|        |              |         | SPI1_MISO   | I/O  | MFP4  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |              |         | UART4_TXD   | O    | MFP5  | UART4 data transmitter output pin.            |
|        |              |         | SC2_PWR     | O    | MFP6  | Smart Card 2 power pin.                       |
|        |              |         | UART0_nCTS  | I    | MFP7  | UART0 clear to Send input pin.                |
|        |              |         | I2C1_SMBAL  | O    | MFP8  | I2C1 SMBus SMBALTER pin                       |
|        |              |         | EPWM1_CH2   | I/O  | MFP11 | EPWM1 channel 2 output/capture input.         |
|        |              |         | BPWM1_CH0   | I/O  | MFP12 | BPWM1 channel 0 output/capture input.         |
|        |              |         | TM0         | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |              | 49      | INT3        | I    | MFP15 | External interrupt 3 input pin.               |
|        |              |         | PC.6        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |              |         | EBI_AD8     | I/O  | MFP2  | EBI address/data bus bit 8.                   |
|        |              |         | SPI1_MOSI   | I/O  | MFP4  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |              |         | UART4_RXD   | I    | MFP5  | UART4 data receiver input pin.                |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |              |         | SC2_RST         | O    | MFP6  | Smart Card 2 reset pin.                                                         |
|        |              |         | UART0_nRTS      | O    | MFP7  | UART0 request to Send output pin.                                               |
|        |              |         | I2C1_SMBSUS     | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)                                       |
|        |              |         | EPWM1_CH3       | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                                           |
|        |              |         | BPWM1_CH1       | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                                           |
|        |              |         | TM1             | I/O  | MFP14 | Timer1 event counter input/toggle output pin.                                   |
|        |              |         | INT2            | I    | MFP15 | External interrupt 2 input pin.                                                 |
|        |              | 50      | PA.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD7         | I/O  | MFP2  | EBI address/data bus bit 7.                                                     |
|        |              |         | SPI1_CLK        | I/O  | MFP4  | SPI1 serial clock pin.                                                          |
|        |              |         | SC2_DAT         | I/O  | MFP6  | Smart Card 2 data pin.                                                          |
|        |              |         | UART0_TXD       | O    | MFP7  | UART0 data transmitter output pin.                                              |
|        |              |         | I2C1_SCL        | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |              |         | EPWM1_CH4       | I/O  | MFP11 | EPWM1 channel 4 output/capture input.                                           |
|        |              |         | BPWM1_CH2       | I/O  | MFP12 | BPWM1 channel 2 output/capture input.                                           |
|        |              |         | ACMP0_WLAT      | I    | MFP13 | Analog comparator 0 window latch input pin                                      |
|        |              |         | TM2             | I/O  | MFP14 | Timer2 event counter input/toggle output pin.                                   |
|        |              |         | INT1            | I    | MFP15 | External interrupt 1 input pin.                                                 |
|        |              | 51      | PA.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD6         | I/O  | MFP2  | EBI address/data bus bit 6.                                                     |
|        |              |         | SPI1_SS         | I/O  | MFP4  | SPI1 slave select pin.                                                          |
|        |              |         | SD1_nCD         | I    | MFP5  | SD/SDIO1 card detect input pin                                                  |
|        |              |         | SC2_CLK         | O    | MFP6  | Smart Card 2 clock pin.                                                         |
|        |              |         | UART0_RXD       | I    | MFP7  | UART0 data receiver input pin.                                                  |
|        |              |         | I2C1_SDA        | I/O  | MFP8  | I2C1 data input/output pin.                                                     |
|        |              |         | EPWM1_CH5       | I/O  | MFP11 | EPWM1 channel 5 output/capture input.                                           |
|        |              |         | BPWM1_CH3       | I/O  | MFP12 | BPWM1 channel 3 output/capture input.                                           |
|        |              |         | ACMP1_WLAT      | I    | MFP13 | Analog comparator 1 window latch input pin                                      |
|        |              |         | TM3             | I/O  | MFP14 | Timer3 event counter input/toggle output pin.                                   |
|        |              |         | INT0            | I    | MFP15 | External interrupt 0 input pin.                                                 |
| 22     | 22           | 52      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 23     | 23           | 53      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 24     | 24           | 54      | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------------|---------|--------------|------|-------|---------------------------------------------|
| 25     | 25           | 55      | PA.5         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | SPIM_D2      | I/O  | MFP2  | SPIM data 2 pin for Quad Mode I/O.          |
|        |              |         | QSPI0_MISO1  | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |              |         | SPI1_I2SMCLK | I/O  | MFP4  | SPI1 I2S master clock output pin            |
|        |              |         | SD1_CMD      | I/O  | MFP5  | SD/SDIO1 command/response pin               |
|        |              |         | SC2_nCD      | I    | MFP6  | Smart Card 2 card detect pin.               |
|        |              |         | UART0_nCTS   | I    | MFP7  | UART0 clear to Send input pin.              |
|        |              |         | UART5_TXD    | O    | MFP8  | UART5 data transmitter output pin.          |
|        |              |         | I2C0_SCL     | I/O  | MFP9  | I2C0 clock pin.                             |
|        |              |         | BPWM0_CH5    | I/O  | MFP12 | BPWM0 channel 5 output/capture input.       |
| 26     | 26           | 56      | PA.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | SPIM_D3      | I/O  | MFP2  | SPIM data 3 pin for Quad Mode I/O.          |
|        |              |         | QSPI0_MOSI1  | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |              |         | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin            |
|        |              |         | SD1_CLK      | O    | MFP5  | SD/SDIO1 clock output pin                   |
|        |              |         | SC0_nCD      | I    | MFP6  | Smart Card 0 card detect pin.               |
|        |              |         | UART0_nRTS   | O    | MFP7  | UART0 request to Send output pin.           |
|        |              |         | UART5_RXD    | I    | MFP8  | UART5 data receiver input pin.              |
|        |              |         | I2C0_SDA     | I/O  | MFP9  | I2C0 data input/output pin.                 |
|        |              |         | BPWM0_CH4    | I/O  | MFP12 | BPWM0 channel 4 output/capture input.       |
| 27     | 27           | 57      | PA.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | SPIM_SS      | I/O  | MFP2  | SPIM slave select pin.                      |
|        |              |         | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                 |
|        |              |         | SPI0_SS      | I/O  | MFP4  | SPI0 slave select pin.                      |
|        |              |         | SD1_DAT3     | I/O  | MFP5  | SD/SDIO1 data line bit 3.                   |
|        |              |         | SC0_PWR      | O    | MFP6  | Smart Card 0 power pin.                     |
|        |              |         | UART4_TXD    | O    | MFP7  | UART4 data transmitter output pin.          |
|        |              |         | UART1_TXD    | O    | MFP8  | UART1 data transmitter output pin.          |
|        |              |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |              |         | BPWM0_CH3    | I/O  | MFP12 | BPWM0 channel 3 output/capture input.       |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------------|---------|-------------|------|-------|---------------------------------------------|
|        |              |         | EPWM0_CH2   | I/O  | MFP13 | EPWM0 channel 2 output/capture input.       |
|        |              |         | QEIO_B      | I    | MFP14 | Quadrature encoder 0 phase B input          |
| 28     | 28           | 58      | PA.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | SPI_M_CLK   | I/O  | MFP2  | SPI_M serial clock pin.                     |
|        |              |         | QSPI0_CLK   | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |              |         | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                      |
|        |              |         | SD1_DAT2    | I/O  | MFP5  | SD/SDIO1 data line bit 2.                   |
|        |              |         | SC0_RST     | O    | MFP6  | Smart Card 0 reset pin.                     |
|        |              |         | UART4_RXD   | I    | MFP7  | UART4 data receiver input pin.              |
|        |              |         | UART1_RXD   | I    | MFP8  | UART1 data receiver input pin.              |
|        |              |         | I2C1_SDA    | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |              |         | BPWM0_CH2   | I/O  | MFP12 | BPWM0 channel 2 output/capture input.       |
|        |              |         | EPWM0_CH3   | I/O  | MFP13 | EPWM0 channel 3 output/capture input.       |
| 29     | 29           | 59      | PA.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | SPI_M_MISO  | I/O  | MFP2  | SPI_M MISO (Master In, Slave Out) pin.      |
|        |              |         | QSPI0_MISO0 | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |              |         | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|        |              |         | SD1_DAT1    | I/O  | MFP5  | SD/SDIO1 data line bit 1.                   |
|        |              |         | SC0_DAT     | I/O  | MFP6  | Smart Card 0 data pin.                      |
|        |              |         | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.          |
|        |              |         | UART1_nCTS  | I    | MFP8  | UART1 clear to Send input pin.              |
|        |              |         | I2C2_SCL    | I/O  | MFP9  | I2C2 clock pin.                             |
|        |              |         | BPWM0_CH1   | I/O  | MFP12 | BPWM0 channel 1 output/capture input.       |
|        |              |         | EPWM0_CH4   | I/O  | MFP13 | EPWM0 channel 4 output/capture input.       |
|        |              |         | DAC1_ST     | I    | MFP15 | DAC1 external trigger input.                |
| 30     | 30           | 60      | PA.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | SPI_M_MOSI  | I/O  | MFP2  | SPI_M MOSI (Master Out, Slave In) pin.      |
|        |              |         | QSPI0_MOSI0 | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|        |              |         | SPI0_MOSI   | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.       |
|        |              |         | SD1_DAT0    | I/O  | MFP5  | SD/SDIO1 data line bit 0.                   |
|        |              |         | SC0_CLK     | O    | MFP6  | Smart Card 0 clock pin.                     |
|        |              |         | UART0_RXD   | I    | MFP7  | UART0 data receiver input pin.              |
|        |              |         | UART1_nRTS  | O    | MFP8  | UART1 request to Send output pin.           |
|        |              |         | I2C2_SDA    | I/O  | MFP9  | I2C2 data input/output pin.                 |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name          | Type | MFP   | Description                                                                                          |
|--------|--------------|---------|-------------------|------|-------|------------------------------------------------------------------------------------------------------|
|        |              |         | BPWM0_CH0         | I/O  | MFP12 | BPWM0 channel 0 output/capture input.                                                                |
|        |              |         | EPWM0_CH5         | I/O  | MFP13 | EPWM0 channel 5 output/capture input.                                                                |
|        |              |         | DAC0_ST           | I    | MFP15 | DAC0 external trigger input.                                                                         |
| 31     | 31           | 61      | V <sub>DDIO</sub> | P    | MFP0  | Power supply for PA.0~PA.5.                                                                          |
|        |              |         | PE.14             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |              |         | EBI_AD8           | I/O  | MFP2  | EBI address/data bus bit 8.                                                                          |
|        |              |         | UART2_TXD         | O    | MFP3  | UART2 data transmitter output pin.                                                                   |
|        |              |         | SD1_nCD           | I    | MFP5  | SD/SDIO1 card detect input pin                                                                       |
|        |              |         | PE.15             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |              |         | EBI_AD9           | I/O  | MFP2  | EBI address/data bus bit 9.                                                                          |
|        |              |         | UART2_RXD         | I    | MFP3  | UART2 data receiver input pin.                                                                       |
| 32     | 32           | 64      | nRESET            | I    | MFP0  | External reset input: active LOW, with an internal pull-up. Set this pin low reset to initial state. |
| 33     | 33           |         | PF.0              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |              |         | UART1_TXD         | O    | MFP2  | UART1 data transmitter output pin.                                                                   |
|        |              |         | I2C1_SCL          | I/O  | MFP3  | I2C1 clock pin.                                                                                      |
|        |              |         | BPWM1_CH0         | I/O  | MFP12 | BPWM1 channel 0 output/capture input.                                                                |
|        |              |         | ICE_DAT           | O    | MFP14 | Serial wired debugger data pin.                                                                      |
| 34     | 34           |         | PF.1              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |              |         | UART1_RXD         | I    | MFP2  | UART1 data receiver input pin.                                                                       |
|        |              |         | I2C1_SDA          | I/O  | MFP3  | I2C1 data input/output pin.                                                                          |
|        |              |         | BPWM1_CH1         | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                                                                |
|        |              |         | ICE_CLK           | I    | MFP14 | Serial wired debugger clock pin.                                                                     |
|        |              |         | PD.9              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |              |         | EBI_AD7           | I/O  | MFP2  | EBI address/data bus bit 7.                                                                          |
|        |              |         | I2C2_SCL          | I/O  | MFP3  | I2C2 clock pin.                                                                                      |
|        |              |         | UART2_nCTS        | I    | MFP4  | UART2 clear to Send input pin.                                                                       |
|        |              |         | PD.8              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |              |         | EBI_AD6           | I/O  | MFP2  | EBI address/data bus bit 6.                                                                          |
|        |              |         | I2C2_SDA          | I/O  | MFP3  | I2C2 data input/output pin.                                                                          |
|        |              |         | UART2_nRTS        | O    | MFP4  | UART2 request to Send output pin.                                                                    |
| 35     |              |         | PC.5              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |              |         | EBI_AD5           | I/O  | MFP2  | EBI address/data bus bit 5.                                                                          |
|        |              |         | SPIM_D2           | I/O  | MFP3  | SPIM data 2 pin for Quad Mode I/O.                                                                   |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------------|---------|--------------|------|-------|---------------------------------------------|
|        |              |         | QSPI0_MISO1  | I/O  | MFP4  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |              |         | UART2_TXD    | O    | MFP8  | UART2 data transmitter output pin.          |
|        |              |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |              |         | UART4_TXD    | O    | MFP11 | UART4 data transmitter output pin.          |
|        |              |         | EPWM1_CH0    | I/O  | MFP12 | EPWM1 channel 0 output/capture input.       |
|        |              | 70      | PC.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | EBI_AD4      | I/O  | MFP2  | EBI address/data bus bit 4.                 |
|        |              |         | SPIM_D3      | I/O  | MFP3  | SPIM data 3 pin for Quad Mode I/O.          |
|        |              |         | QSPI0_MOSI1  | I/O  | MFP4  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |              |         | SC1_nCD      | I    | MFP5  | Smart Card 1 card detect pin.               |
|        |              |         | I2S0_BCLK    | O    | MFP6  | I2S0 bit clock output pin.                  |
|        |              |         | SPI1_I2SMCLK | I/O  | MFP7  | SPI1 I2S master clock output pin            |
|        |              |         | UART2_RXD    | I    | MFP8  | UART2 data receiver input pin.              |
|        |              |         | I2C1_SDA     | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |              |         | UART4_RXD    | I    | MFP11 | UART4 data receiver input pin.              |
|        |              | 71      | PC.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | EBI_AD3      | I/O  | MFP2  | EBI address/data bus bit 3.                 |
|        |              |         | SPIM_SS      | I/O  | MFP3  | SPIM slave select pin.                      |
|        |              |         | QSPI0_SS     | I/O  | MFP4  | Quad SPI0 slave select pin.                 |
|        |              |         | SC1_PWR      | O    | MFP5  | Smart Card 1 power pin.                     |
|        |              |         | I2S0_MCLK    | O    | MFP6  | I2S0 master clock output pin.               |
|        |              |         | SPI1_MISO    | I/O  | MFP7  | SPI1 MISO (Master In, Slave Out) pin.       |
|        |              |         | UART2_nRTS   | O    | MFP8  | UART2 request to Send output pin.           |
|        |              |         | I2C0_SMBAL   | O    | MFP9  | I2C0 SMBus SMBALTER pin                     |
|        |              |         | UART3_TXD    | O    | MFP11 | UART3 data transmitter output pin.          |
|        |              | 72      | EPWM1_CH2    | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        |              |         | PC.2         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |              |         | EBI_AD2      | I/O  | MFP2  | EBI address/data bus bit 2.                 |
|        |              |         | SPIM_CLK     | I/O  | MFP3  | SPIM serial clock pin.                      |
|        |              |         | QSPI0_CLK    | I/O  | MFP4  | Quad SPI0 serial clock pin.                 |
|        |              |         | SC1_RST      | O    | MFP5  | Smart Card 1 reset pin.                     |
|        |              |         | I2S0_DI      | I    | MFP6  | I2S0 data input pin.                        |
|        |              |         | SPI1_MOSI    | I/O  | MFP7  | SPI1 MOSI (Master Out, Slave In) pin.       |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |              |         | UART2_nCTS      | I    | MFP8  | UART2 clear to Send input pin.                                                  |
|        |              |         | I2C0_SMBSUS     | O    | MFP9  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)                                       |
|        |              |         | UART3_RXD       | I    | MFP11 | UART3 data receiver input pin.                                                  |
|        |              |         | EPWM1_CH3       | I/O  | MFP12 | EPWM1 channel 3 output/capture input.                                           |
| 39     | 35           | 73      | PC.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD1         | I/O  | MFP2  | EBI address/data bus bit 1.                                                     |
|        |              |         | SPIM_MISO       | I/O  | MFP3  | SPIM MISO (Master In, Slave Out) pin.                                           |
|        |              |         | QSPI0_MISO0     | I/O  | MFP4  | Quad SPI0 MISO0 (Master In, Slave Out) pin.                                     |
|        |              |         | SC1_DAT         | I/O  | MFP5  | Smart Card 1 data pin.                                                          |
|        |              |         | I2S0_DO         | O    | MFP6  | I2S0 data output pin.                                                           |
|        |              |         | SPI1_CLK        | I/O  | MFP7  | SPI1 serial clock pin.                                                          |
|        |              |         | UART2_TXD       | O    | MFP8  | UART2 data transmitter output pin.                                              |
|        |              |         | I2C0_SCL        | I/O  | MFP9  | I2C0 clock pin.                                                                 |
|        |              |         | EPWM1_CH4       | I/O  | MFP12 | EPWM1 channel 4 output/capture input.                                           |
| 40     | 36           | 74      | ACMP0_O         | O    | MFP14 | Analog comparator 0 output pin.                                                 |
|        |              |         | PC.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD0         | I/O  | MFP2  | EBI address/data bus bit 0.                                                     |
|        |              |         | SPIM_MOSI       | I/O  | MFP3  | SPIM MOSI (Master Out, Slave In) pin.                                           |
|        |              |         | QSPI0_MOSI0     | I/O  | MFP4  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.                                     |
|        |              |         | SC1_CLK         | O    | MFP5  | Smart Card 1 clock pin.                                                         |
|        |              |         | I2S0_LRCK       | O    | MFP6  | I2S0 left right channel clock output pin.                                       |
|        |              |         | SPI1_SS         | I/O  | MFP7  | SPI1 slave select pin.                                                          |
|        |              |         | UART2_RXD       | I    | MFP8  | UART2 data receiver input pin.                                                  |
|        |              |         | I2C0_SDA        | I/O  | MFP9  | I2C0 data input/output pin.                                                     |
|        |              | 75      | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |              |         | ACMP1_O         | O    | MFP14 | Analog comparator 1 output pin.                                                 |
|        |              |         | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |              |         | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |              |         | PG.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              | 77      | EBI_AD0         | I/O  | MFP2  | EBI address/data bus bit 0.                                                     |
|        |              |         | SD1_DAT3        | I/O  | MFP3  | SD/SDIO1 data line bit 3.                                                       |
|        |              |         | SPIM_D2         | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.                                              |
|        |              |         | BPWM0_CH5       | I/O  | MFP12 | BPWM0 channel 5 output/capture input.                                           |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|--------------|---------|--------------|------|-------|---------------------------------------|
|        |              | 78      | PG.10        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_AD1      | I/O  | MFP2  | EBI address/data bus bit 1.           |
|        |              |         | SD1_DAT2     | I/O  | MFP3  | SD/SDIO1 data line bit 2.             |
|        |              |         | SPIM_D3      | I/O  | MFP4  | SPIM data 3 pin for Quad Mode I/O.    |
|        |              |         | BPWM0_CH4    | I/O  | MFP12 | BPWM0 channel 4 output/capture input. |
|        |              | 79      | PG.11        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_AD2      | I/O  | MFP2  | EBI address/data bus bit 2.           |
|        |              |         | SD1_DAT1     | I/O  | MFP3  | SD/SDIO1 data line bit 1.             |
|        |              |         | SPIM_SS      | I/O  | MFP4  | SPIM slave select pin.                |
|        |              |         | BPWM0_CH3    | I/O  | MFP12 | BPWM0 channel 3 output/capture input. |
|        |              | 80      | PG.12        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_AD3      | I/O  | MFP2  | EBI address/data bus bit 3.           |
|        |              |         | SD1_DAT0     | I/O  | MFP3  | SD/SDIO1 data line bit 0.             |
|        |              |         | SPIM_CLK     | I/O  | MFP4  | SPIM serial clock pin.                |
|        |              |         | BPWM0_CH2    | I/O  | MFP12 | BPWM0 channel 2 output/capture input. |
|        |              | 81      | PG.13        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_AD4      | I/O  | MFP2  | EBI address/data bus bit 4.           |
|        |              |         | SD1_CMD      | I/O  | MFP3  | SD/SDIO1 command/response pin         |
|        |              |         | SPIM_MISO    | I/O  | MFP4  | SPIM MISO (Master In, Slave Out) pin. |
|        |              |         | BPWM0_CH1    | I/O  | MFP12 | BPWM0 channel 1 output/capture input. |
|        |              | 82      | PG.14        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_AD5      | I/O  | MFP2  | EBI address/data bus bit 5.           |
|        |              |         | SD1_CLK      | O    | MFP3  | SD/SDIO1 clock output pin             |
|        |              |         | SPIM_MOSI    | I/O  | MFP4  | SPIM MOSI (Master Out, Slave In) pin. |
|        |              |         | BPWM0_CH0    | I/O  | MFP12 | BPWM0 channel 0 output/capture input. |
|        |              | 83      | PG.15        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | SD1_nCD      | I    | MFP3  | SD/SDIO1 card detect input pin        |
|        |              |         | CLKO         | O    | MFP14 | Clock Out                             |
|        |              |         | EADCO_ST     | I    | MFP15 | EADC0 external trigger input.         |
|        |              | 84      | PD.13        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_AD10     | I/O  | MFP2  | EBI address/data bus bit 10.          |
|        |              |         | SD0_nCD      | I    | MFP3  | SD/SDIO0 card detect input pin        |
|        |              |         | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin      |
|        |              |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin      |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name   | Type | MFP   | Description                           |
|--------|--------------|---------|------------|------|-------|---------------------------------------|
|        |              |         | SC2_nCD    | I    | MFP7  | Smart Card 2 card detect pin.         |
|        | 37           | 85      | PA.12      | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | I2S0_BCLK  | O    | MFP2  | I2S0 bit clock output pin.            |
|        |              |         | UART4_TXD  | O    | MFP3  | UART4 data transmitter output pin.    |
|        |              |         | I2C1_SCL   | I/O  | MFP4  | I2C1 clock pin.                       |
|        |              |         | SPI2_SS    | I/O  | MFP5  | SPI2 slave select pin.                |
|        |              |         | SC2_PWR    | O    | MFP7  | Smart Card 2 power pin.               |
|        |              |         | BPWM1_CH2  | I/O  | MFP11 | BPWM1 channel 2 output/capture input. |
|        |              |         | QEI1_INDEX | I    | MFP12 | Quadrature encoder 1 index input      |
|        |              |         | USB_VBUS   | P    | MFP14 | Power supply from USB host or HUB.    |
|        | 38           | 86      | PA.13      | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | I2S0_MCLK  | O    | MFP2  | I2S0 master clock output pin.         |
|        |              |         | UART4_RXD  | I    | MFP3  | UART4 data receiver input pin.        |
|        |              |         | I2C1_SDA   | I/O  | MFP4  | I2C1 data input/output pin.           |
|        |              |         | SPI2_CLK   | I/O  | MFP5  | SPI2 serial clock pin.                |
|        |              |         | SC2_RST    | O    | MFP7  | Smart Card 2 reset pin.               |
|        |              |         | BPWM1_CH3  | I/O  | MFP11 | BPWM1 channel 3 output/capture input. |
|        |              |         | QEI1_A     | I    | MFP12 | Quadrature encoder 1 phase A input    |
|        |              |         | USB_D-     | A    | MFP14 | USB differential signal D-.           |
|        | 39           | 87      | PA.14      | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | I2S0_DI    | I    | MFP2  | I2S0 data input pin.                  |
|        |              |         | UART0_TXD  | O    | MFP3  | UART0 data transmitter output pin.    |
|        |              |         | SPI2_MISO  | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin. |
|        |              |         | I2C2_SCL   | I/O  | MFP6  | I2C2 clock pin.                       |
|        |              |         | SC2_DAT    | I/O  | MFP7  | Smart Card 2 data pin.                |
|        |              |         | BPWM1_CH4  | I/O  | MFP11 | BPWM1 channel 4 output/capture input. |
|        |              |         | QEI1_B     | I    | MFP12 | Quadrature encoder 1 phase B input    |
|        |              |         | USB_D+     | A    | MFP14 | USB differential signal D+.           |
|        | 40           | 88      | PA.15      | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | I2S0_DO    | O    | MFP2  | I2S0 data output pin.                 |
|        |              |         | UART0_RXD  | I    | MFP3  | UART0 data receiver input pin.        |
|        |              |         | SPI2_MOSI  | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin. |
|        |              |         | I2C2_SDA   | I/O  | MFP6  | I2C2 data input/output pin.           |
|        |              |         | SC2_CLK    | O    | MFP7  | Smart Card 2 clock pin.               |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type | MFP   | Description                                                                                                              |
|--------|--------------|---------|-----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------|
|        |              |         | BPWM1_CH5       | I/O  | MFP11 | BPWM1 channel 5 output/capture input.                                                                                    |
|        |              |         | EPWM0_SYNC_IN   | I    | MFP12 | EPWM0 counter synchronous trigger input pin.                                                                             |
|        |              |         | USB_OTG_ID      | I    | MFP14 | USB_ identification.                                                                                                     |
| 41     | 41           | 89      | HSUSB_VRES      | A    | MFP0  | HSUSB module reference resister                                                                                          |
| 42     | 42           | 90      | HSUSB_VDD33     | P    | MFP0  | Power supply for HSUSB VDD33                                                                                             |
| 43     | 43           | 91      | HSUSB_VBUS      | P    | MFP0  | HSUSB Power supply from USB host or HUB.                                                                                 |
| 44     | 44           | 92      | HSUSB_D-        | A    | MFP0  | HSUSB differential signal D-.                                                                                            |
| 45     | 45           | 93      | HSUSB_VSS       | P    | MFP0  | Ground pin for HSUSB.                                                                                                    |
| 46     | 46           | 94      | HSUSB_D+        | A    | MFP0  | HSUSB differential signal D+.                                                                                            |
| 47     | 47           | 95      | HSUSB_VDD12_CAP | A    | MFP0  | HSUSB Internal power regulator output 1.2V decoupling pin.<br>Note: This pin needs to be connected with a 1uF capacitor. |
| 48     | 48           | 96      | HSUSB_ID        | I    | MFP0  | HSUSB identification.                                                                                                    |
|        |              | 97      | PE.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |              |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                                                            |
|        |              |         | SPIM_D2         | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.                                                                                       |
|        |              |         | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.                                                                                       |
|        |              |         | QEI1_INDEX      | I    | MFP11 | Quadrature encoder 1 index input                                                                                         |
|        |              |         | EPWM0_CH0       | I/O  | MFP12 | EPWM0 channel 0 output/capture input.                                                                                    |
|        |              |         | BPWM0_CH5       | I/O  | MFP13 | BPWM0 channel 5 output/capture input.                                                                                    |
|        |              | 98      | PE.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |              |         | SD0_CLK         | O    | MFP3  | SD/SDIO0 clock output pin                                                                                                |
|        |              |         | SPIM_D3         | I/O  | MFP4  | SPIM data 3 pin for Quad Mode I/O.                                                                                       |
|        |              |         | SPI3_I2SMCLK    | I/O  | MFP5  | SPI3 I2S master clock output pin                                                                                         |
|        |              |         | SC0_nCD         | I    | MFP6  | Smart Card 0 card detect pin.                                                                                            |
|        |              |         | USCI0_CTL0      | I/O  | MFP7  | USCI0 control 0 pin.                                                                                                     |
|        |              |         | UART5_RXD       | I    | MFP8  | UART5 data receiver input pin.                                                                                           |
|        |              |         | QEI1_A          | I    | MFP11 | Quadrature encoder 1 phase A input                                                                                       |
|        |              |         | EPWM0_CH1       | I/O  | MFP12 | EPWM0 channel 1 output/capture input.                                                                                    |
|        |              | 99      | BPWM0_CH4       | I/O  | MFP13 | BPWM0 channel 4 output/capture input.                                                                                    |
|        |              |         | PE.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |              |         | EBI_nRD         | O    | MFP2  | EBI read enable output pin.                                                                                              |
|        |              |         | SD0_DAT3        | I/O  | MFP3  | SD/SDIO0 data line bit 3.                                                                                                |
|        |              |         | SPIM_SS         | I/O  | MFP4  | SPIM slave select pin.                                                                                                   |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name   | Type | MFP   | Description                           |
|--------|--------------|---------|------------|------|-------|---------------------------------------|
|        |              |         | SPI3_SS    | I/O  | MFP5  | SPI3 slave select pin.                |
|        |              |         | SC0_PWR    | O    | MFP6  | Smart Card 0 power pin.               |
|        |              |         | USCI0_CTL1 | I/O  | MFP7  | USCI0 control 1 pin.                  |
|        |              |         | QEI1_B     | I    | MFP11 | Quadrature encoder 1 phase B input    |
|        |              |         | EPWM0_CH2  | I/O  | MFP12 | EPWM0 channel 2 output/capture input. |
|        |              |         | BPWM0_CH3  | I/O  | MFP13 | BPWM0 channel 3 output/capture input. |
|        |              | 100     | PE.4       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_nWR    | O    | MFP2  | EBI write enable output pin.          |
|        |              |         | SD0_DAT2   | I/O  | MFP3  | SD/SDIO0 data line bit 2.             |
|        |              |         | SPIM_CLK   | I/O  | MFP4  | SPIM serial clock pin.                |
|        |              |         | SPI3_CLK   | I/O  | MFP5  | SPI3 serial clock pin.                |
|        |              |         | SC0_RST    | O    | MFP6  | Smart Card 0 reset pin.               |
|        |              |         | USCI0_DAT1 | I/O  | MFP7  | USCI0 data 1 pin.                     |
|        |              |         | QEI0_INDEX | I    | MFP11 | Quadrature encoder 0 index input      |
|        |              |         | EPWM0_CH3  | I/O  | MFP12 | EPWM0 channel 3 output/capture input. |
|        |              |         | BPWM0_CH2  | I/O  | MFP13 | BPWM0 channel 2 output/capture input. |
|        |              | 101     | PE.3       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.        |
|        |              |         | SD0_DAT1   | I/O  | MFP3  | SD/SDIO0 data line bit 1.             |
|        |              |         | SPIM_MISO  | I/O  | MFP4  | SPIM MISO (Master In, Slave Out) pin. |
|        |              |         | SPI3_MISO  | I/O  | MFP5  | SPI3 MISO (Master In, Slave Out) pin. |
|        |              |         | SC0_DAT    | I/O  | MFP6  | Smart Card 0 data pin.                |
|        |              |         | USCI0_DAT0 | I/O  | MFP7  | USCI0 data 0 pin.                     |
|        |              |         | QEI0_A     | I    | MFP11 | Quadrature encoder 0 phase A input    |
|        |              |         | EPWM0_CH4  | I/O  | MFP12 | EPWM0 channel 4 output/capture input. |
|        |              |         | BPWM0_CH1  | I/O  | MFP13 | BPWM0 channel 1 output/capture input. |
|        |              | 102     | PE.2       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |              |         | EBI_ALE    | O    | MFP2  | EBI address latch enable output pin.  |
|        |              |         | SD0_DAT0   | I/O  | MFP3  | SD/SDIO0 data line bit 0.             |
|        |              |         | SPIM_MOSI  | I/O  | MFP4  | SPIM MOSI (Master Out, Slave In) pin. |
|        |              |         | SPI3_MOSI  | I/O  | MFP5  | SPI3 MOSI (Master Out, Slave In) pin. |
|        |              |         | SC0_CLK    | O    | MFP6  | Smart Card 0 clock pin.               |
|        |              |         | USCI0_CLK  | I/O  | MFP7  | USCI0 clock pin.                      |
|        |              |         | QEI0_B     | I    | MFP11 | Quadrature encoder 0 phase B input    |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |              |         | EPWM0_CH5       | I/O  | MFP12 | EPWM0 channel 5 output/capture input.                                           |
|        |              |         | BPWM0_CH0       | I/O  | MFP13 | BPWM0 channel 0 output/capture input.                                           |
|        |              | 103     | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |              | 104     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |              | 105     | PE.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD10        | I/O  | MFP2  | EBI address/data bus bit 10.                                                    |
|        |              |         | QSPI0_MISO0     | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin.                                     |
|        |              |         | SC2_DAT         | I/O  | MFP4  | Smart Card 2 data pin.                                                          |
|        |              |         | I2S0_BCLK       | O    | MFP5  | I2S0 bit clock output pin.                                                      |
|        |              |         | SPI1_MISO       | I/O  | MFP6  | SPI1 MISO (Master In, Slave Out) pin.                                           |
|        |              |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |              |         | I2C1_SCL        | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |              |         | UART4_nCTS      | I    | MFP9  | UART4 clear to Send input pin.                                                  |
|        |              |         | 106             | PE.0 | MFP0  | General purpose digital I/O pin.                                                |
|        |              | 106     | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |              |         | QSPI0_MOSI0     | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.                                     |
|        |              |         | SC2_CLK         | O    | MFP4  | Smart Card 2 clock pin.                                                         |
|        |              |         | I2S0_MCLK       | O    | MFP5  | I2S0 master clock output pin.                                                   |
|        |              |         | SPI1_MOSI       | I/O  | MFP6  | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|        |              |         | UART3_RXD       | I    | MFP7  | UART3 data receiver input pin.                                                  |
|        |              |         | I2C1_SDA        | I/O  | MFP8  | I2C1 data input/output pin.                                                     |
|        |              |         | UART4_nRTS      | O    | MFP9  | UART4 request to Send output pin.                                               |
|        |              |         | 107             | PH.8 | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD12        | I/O  | MFP2  | EBI address/data bus bit 12.                                                    |
|        |              | 107     | QSPI0_CLK       | I/O  | MFP3  | Quad SPI0 serial clock pin.                                                     |
|        |              |         | SC2_PWR         | O    | MFP4  | Smart Card 2 power pin.                                                         |
|        |              |         | I2S0_DI         | I    | MFP5  | I2S0 data input pin.                                                            |
|        |              |         | SPI1_CLK        | I/O  | MFP6  | SPI1 serial clock pin.                                                          |
|        |              |         | UART3_nRTS      | O    | MFP7  | UART3 request to Send output pin.                                               |
|        |              |         | I2C1_SMBAL      | O    | MFP8  | I2C1 SMBus SMBALTER pin                                                         |
|        |              |         | I2C2_SCL        | I/O  | MFP9  | I2C2 clock pin.                                                                 |
|        |              |         | UART1_TXD       | O    | MFP10 | UART1 data transmitter output pin.                                              |
|        |              | 108     | PH.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name        | Type  | MFP   | Description                                                                     |
|--------|--------------|---------|-----------------|-------|-------|---------------------------------------------------------------------------------|
|        |              |         | EBI_AD13        | I/O   | MFP2  | EBI address/data bus bit 13.                                                    |
|        |              |         | QSPI0_SS        | I/O   | MFP3  | Quad SPI0 slave select pin.                                                     |
|        |              |         | SC2_RST         | O     | MFP4  | Smart Card 2 reset pin.                                                         |
|        |              |         | I2S0_DO         | O     | MFP5  | I2S0 data output pin.                                                           |
|        |              |         | SPI1_SS         | I/O   | MFP6  | SPI1 slave select pin.                                                          |
|        |              |         | UART3_nCTS      | I     | MFP7  | UART3 clear to Send input pin.                                                  |
|        |              |         | I2C1_SMBSUS     | O     | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)                                       |
|        |              |         | I2C2_SDA        | I/O   | MFP9  | I2C2 data input/output pin.                                                     |
|        |              |         | UART1_RXD       | I     | MFP10 | UART1 data receiver input pin.                                                  |
|        |              |         | 109             | PH.10 | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD14        | I/O   | MFP2  | EBI address/data bus bit 14.                                                    |
|        |              |         | QSPI0_MISO1     | I/O   | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin.                                     |
|        |              |         | SC2_nCD         | I     | MFP4  | Smart Card 2 card detect pin.                                                   |
|        |              |         | I2S0_LRCK       | O     | MFP5  | I2S0 left right channel clock output pin.                                       |
|        |              |         | SPI1_I2SMCLK    | I/O   | MFP6  | SPI1 I2S master clock output pin                                                |
|        |              |         | UART4_TXD       | O     | MFP7  | UART4 data transmitter output pin.                                              |
|        |              |         | UART0_TXD       | O     | MFP8  | UART0 data transmitter output pin.                                              |
|        |              |         | 110             | PH.11 | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD15        | I/O   | MFP2  | EBI address/data bus bit 15.                                                    |
|        |              |         | QSPI0_MOSI1     | I/O   | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin.                                     |
|        |              |         | UART4_RXD       | I     | MFP7  | UART4 data receiver input pin.                                                  |
|        |              |         | UART0_RXD       | I     | MFP8  | UART0 data receiver input pin.                                                  |
|        |              |         | EPWM0_CH5       | I/O   | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |              |         | 111             | PD.14 | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_nCS0        | O     | MFP2  | EBI chip select 0 output pin.                                                   |
|        |              |         | SPI3_I2SMCLK    | I/O   | MFP3  | SPI3 I2S master clock output pin                                                |
|        |              |         | SC1_nCD         | I     | MFP4  | Smart Card 1 card detect pin.                                                   |
|        |              |         | EPWM0_CH4       | I/O   | MFP11 | EPWM0 channel 4 output/capture input.                                           |
| 49     | 49           | 112     | V <sub>ss</sub> | P     | MFP0  | Ground pin for digital circuit.                                                 |
| 50     | 50           | 113     | LDO_CAP         | A     | MFP0  | LDO output pin.                                                                 |
| 51     | 51           | 114     | V <sub>DD</sub> | P     | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |              |         | PC.14           | I/O   | MFP0  | General purpose digital I/O pin.                                                |
|        |              |         | EBI_AD11        | I/O   | MFP2  | EBI address/data bus bit 11.                                                    |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name      | Type | MFP   | Description                                      |
|--------|--------------|---------|---------------|------|-------|--------------------------------------------------|
|        |              |         | SC1_nCD       | I    | MFP3  | Smart Card 1 card detect pin.                    |
|        |              |         | SPI0_I2SMCLK  | I/O  | MFP4  | SPI0 I2S master clock output pin                 |
|        |              |         | USCI0_CTL0    | I/O  | MFP5  | USCI0 control 0 pin.                             |
|        |              |         | QSPI0_CLK     | I/O  | MFP6  | Quad SPI0 serial clock pin.                      |
|        |              |         | EPWM0_SYNC_IN | I    | MFP11 | EPWM0 counter synchronous trigger input pin.     |
|        |              |         | TM1           | I/O  | MFP13 | Timer1 event counter input/toggle output pin.    |
|        |              |         | USB_VBUS_ST   | I    | MFP14 | USB external VBUS regulator status pin.          |
|        |              |         | HSUSB_VBUS_ST | I    | MFP15 | HSUSB external VBUS regulator status pin.        |
|        |              | 53      | PB.15         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |              |         | EADC0_CH15    | A    | MFP1  | EADC0 channel 15 analog input.                   |
|        |              |         | EBI_AD12      | I/O  | MFP2  | EBI address/data bus bit 12.                     |
|        |              |         | SC1_PWR       | O    | MFP3  | Smart Card 1 power pin.                          |
|        |              |         | SPI0_SS       | I/O  | MFP4  | SPI0 slave select pin.                           |
|        |              |         | USCI0_CTL1    | I/O  | MFP5  | USCI0 control 1 pin.                             |
|        |              |         | UART0_nCTS    | I    | MFP6  | UART0 clear to Send input pin.                   |
|        |              |         | UART3_TXD     | O    | MFP7  | UART3 data transmitter output pin.               |
|        |              |         | I2C2_SMBAL    | O    | MFP8  | I2C2 SMBus SMBALTER pin                          |
|        |              |         | EPWM1_CH0     | I/O  | MFP11 | EPWM1 channel 0 output/capture input.            |
|        |              |         | TM0_EXT       | I/O  | MFP13 | Timer0 external capture input/toggle output pin. |
|        |              |         | USB_VBUS_EN   | O    | MFP14 | USB external VBUS regulator enable pin.          |
|        |              |         | HSUSB_VBUS_EN | O    | MFP15 | HSUSB external VBUS regulator enable pin.        |
|        |              | 54      | PB.14         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |              |         | EADC0_CH14    | A    | MFP1  | EADC0 channel 14 analog input.                   |
|        |              |         | EBI_AD13      | I/O  | MFP2  | EBI address/data bus bit 13.                     |
|        |              |         | SC1_RST       | O    | MFP3  | Smart Card 1 reset pin.                          |
|        |              |         | SPI0_CLK      | I/O  | MFP4  | SPI0 serial clock pin.                           |
|        |              |         | USCI0_DAT1    | I/O  | MFP5  | USCI0 data 1 pin.                                |
|        |              |         | UART0_nRTS    | O    | MFP6  | UART0 request to Send output pin.                |
|        |              |         | UART3_RXD     | I    | MFP7  | UART3 data receiver input pin.                   |
|        |              |         | I2C2_SMBSUS   | O    | MFP8  | I2C2 SMBus SMBSUS pin (PMBus CONTROL pin)        |
|        |              |         | EPWM1_CH1     | I/O  | MFP11 | EPWM1 channel 1 output/capture input.            |
|        |              |         | TM1_EXT       | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |              |         | CLKO          | O    | MFP14 | Clock Out                                        |
| 55     | 55           | 118     | PB.13         | I/O  | MFP0  | General purpose digital I/O pin.                 |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name         | Type | MFP   | Description                                                                                |
|--------|--------------|---------|------------------|------|-------|--------------------------------------------------------------------------------------------|
|        |              |         | EADC0_CH13       | A    | MFP1  | EADC0 channel 13 analog input.                                                             |
|        |              |         | DAC1_OUT         | A    | MFP1  | DAC1 channel analog output.                                                                |
|        |              |         | ACMP0_P3         | A    | MFP1  | Analog comparator 0 positive input 3 pin.                                                  |
|        |              |         | ACMP1_P3         | A    | MFP1  | Analog comparator 1 positive input 3 pin.                                                  |
|        |              |         | EBI_AD14         | I/O  | MFP2  | EBI address/data bus bit 14.                                                               |
|        |              |         | SC1_DAT          | I/O  | MFP3  | Smart Card 1 data pin.                                                                     |
|        |              |         | SPI0_MISO        | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.                                                      |
|        |              |         | USCI0_DAT0       | I/O  | MFP5  | USCI0 data 0 pin.                                                                          |
|        |              |         | UART0_TXD        | O    | MFP6  | UART0 data transmitter output pin.                                                         |
|        |              |         | UART3_nRTS       | O    | MFP7  | UART3 request to Send output pin.                                                          |
|        |              |         | I2C2_SCL         | I/O  | MFP8  | I2C2 clock pin.                                                                            |
|        |              |         | EPWM1_CH2        | I/O  | MFP11 | EPWM1 channel 2 output/capture input.                                                      |
|        |              |         | TM2_EXT          | I/O  | MFP13 | Timer2 external capture input/toggle output pin.                                           |
|        |              | 119     | PB.12            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |              |         | EADC0_CH12       | A    | MFP1  | EADC0 channel 12 analog input.                                                             |
|        |              |         | DAC0_OUT         | A    | MFP1  | DAC0 channel analog output.                                                                |
|        |              |         | ACMP0_P2         | A    | MFP1  | Analog comparator 0 positive input 2 pin.                                                  |
|        |              |         | ACMP1_P2         | A    | MFP1  | Analog comparator 1 positive input 2 pin.                                                  |
|        |              |         | EBI_AD15         | I/O  | MFP2  | EBI address/data bus bit 15.                                                               |
|        |              |         | SC1_CLK          | O    | MFP3  | Smart Card 1 clock pin.                                                                    |
|        |              |         | SPI0_MOSI        | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.                                                      |
|        |              |         | USCI0_CLK        | I/O  | MFP5  | USCI0 clock pin.                                                                           |
|        |              |         | UART0_RXD        | I    | MFP6  | UART0 data receiver input pin.                                                             |
|        |              |         | UART3_nCTS       | I    | MFP7  | UART3 clear to Send input pin.                                                             |
|        |              |         | I2C2_SDA         | I/O  | MFP8  | I2C2 data input/output pin.                                                                |
|        |              |         | SD0_nCD          | I    | MFP9  | SD/SDIO0 card detect input pin                                                             |
|        |              |         | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                                                      |
|        |              | 120     | TM3_EXT          | I/O  | MFP13 | Timer3 external capture input/toggle output pin.                                           |
|        |              |         | AV <sub>DD</sub> | P    | MFP0  | Power supply for internal analog circuit.                                                  |
| 58     | 58           | 121     | V <sub>REF</sub> | A    | MFP0  | ADC reference voltage input.<br>Note: This pin needs to be connected with a 1uF capacitor. |
| 59     | 59           | 122     | AV <sub>SS</sub> | P    | MFP0  | Ground pin for analog circuit.                                                             |
|        |              | 123     | PB.11            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |              |         | EADC0_CH11       | A    | MFP1  | EADC0 channel 11 analog input.                                                             |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name      | Type | MFP   | Description                               |
|--------|--------------|---------|---------------|------|-------|-------------------------------------------|
|        |              |         | EBI_ADR16     | O    | MFP2  | EBI address bus bit 16.                   |
|        |              |         | UART0_nCTS    | I    | MFP5  | UART0 clear to Send input pin.            |
|        |              |         | UART4_TXD     | O    | MFP6  | UART4 data transmitter output pin.        |
|        |              |         | I2C1_SCL      | I/O  | MFP7  | I2C1 clock pin.                           |
|        |              |         | SPI0_I2SMCLK  | I/O  | MFP9  | SPI0 I2S master clock output pin          |
|        |              |         | BPWM1_CH0     | I/O  | MFP10 | BPWM1 channel 0 output/capture input.     |
|        |              |         | SPI3_CLK      | I/O  | MFP11 | SPI3 serial clock pin.                    |
|        |              |         | HSUSB_VBUS_ST | I    | MFP14 | HSUSB external VBUS regulator status pin. |
|        |              |         | PB.10         | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EADC0_CH10    | A    | MFP1  | EADC0 channel 10 analog input.            |
|        |              |         | EBI_ADR17     | O    | MFP2  | EBI address bus bit 17.                   |
|        |              |         | USCI1_CTL0    | I/O  | MFP4  | USCI1 control 0 pin.                      |
|        |              |         | UART0_nRTS    | O    | MFP5  | UART0 request to Send output pin.         |
|        |              |         | UART4_RXD     | I    | MFP6  | UART4 data receiver input pin.            |
|        |              |         | I2C1_SDA      | I/O  | MFP7  | I2C1 data input/output pin.               |
|        |              |         | BPWM1_CH1     | I/O  | MFP10 | BPWM1 channel 1 output/capture input.     |
|        |              |         | SPI3_SS       | I/O  | MFP11 | SPI3 slave select pin.                    |
|        |              |         | HSUSB_VBUS_EN | O    | MFP14 | HSUSB external VBUS regulator enable pin. |
|        |              |         | PB.9          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EADC0_CH9     | A    | MFP1  | EADC0 channel 9 analog input.             |
|        |              |         | EBI_ADR18     | O    | MFP2  | EBI address bus bit 18.                   |
|        |              |         | USCI1_CTL1    | I/O  | MFP4  | USCI1 control 1 pin.                      |
|        |              |         | UART0_TXD     | O    | MFP5  | UART0 data transmitter output pin.        |
|        |              |         | UART1_nCTS    | I    | MFP6  | UART1 clear to Send input pin.            |
|        |              |         | I2C1_SMBAL    | O    | MFP7  | I2C1 SMBus SMBALTER pin                   |
|        |              |         | BPWM1_CH2     | I/O  | MFP10 | BPWM1 channel 2 output/capture input.     |
|        |              |         | SPI3_MISO     | I/O  | MFP11 | SPI3 MISO (Master In, Slave Out) pin.     |
|        |              |         | INT7          | I    | MFP13 | External interrupt 7 input pin.           |
|        |              |         | PB.8          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EADC0_CH8     | A    | MFP1  | EADC0 channel 8 analog input.             |
|        |              |         | EBI_ADR19     | O    | MFP2  | EBI address bus bit 19.                   |
|        |              |         | USCI1_CLK     | I/O  | MFP4  | USCI1 clock pin.                          |
|        |              |         | UART0_RXD     | I    | MFP5  | UART0 data receiver input pin.            |
|        |              |         | UART1_nRTS    | O    | MFP6  | UART1 request to Send output pin.         |

| 64 Pin | 64 Pin 2 USB | 128 Pin | Pin Name     | Type | MFP   | Description                               |
|--------|--------------|---------|--------------|------|-------|-------------------------------------------|
|        |              |         | I2C1_SMBSUS  | O    | MFP7  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|        |              |         | BPWM1_CH3    | I/O  | MFP10 | BPWM1 channel 3 output/capture input.     |
|        |              |         | SPI3_MOSI    | I/O  | MFP11 | SPI3 MOSI (Master Out, Slave In) pin.     |
|        |              |         | INT6         | I    | MFP13 | External interrupt 6 input pin.           |
|        |              | 127     | PB.7         | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EADC0_CH7    | A    | MFP1  | EADC0 channel 7 analog input.             |
|        |              |         | EBI_nWRL     | O    | MFP2  | EBI low byte write enable output pin.     |
|        |              |         | USCI1_DAT0   | I/O  | MFP4  | USCI1 data 0 pin.                         |
|        |              |         | UART1_TXD    | O    | MFP6  | UART1 data transmitter output pin.        |
|        |              |         | SD1_CMD      | I/O  | MFP7  | SD/SDIO1 command/response pin             |
|        |              |         | EBI_nCS0     | O    | MFP8  | EBI chip select 0 output pin.             |
|        |              |         | BPWM1_CH4    | I/O  | MFP10 | BPWM1 channel 4 output/capture input.     |
|        |              |         | EPWM1_BRAKE0 | I    | MFP11 | EPWM1 Brake 0 input pin.                  |
|        |              |         | EPWM1_CH4    | I/O  | MFP12 | EPWM1 channel 4 output/capture input.     |
|        |              |         | INT5         | I    | MFP13 | External interrupt 5 input pin.           |
|        |              |         | USB_VBUS_ST  | I    | MFP14 | USB external VBUS regulator status pin.   |
|        |              |         | ACMP0_O      | O    | MFP15 | Analog comparator 0 output pin.           |
|        |              | 128     | PB.6         | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |              |         | EADC0_CH6    | A    | MFP1  | EADC0 channel 6 analog input.             |
|        |              |         | EBI_nWRH     | O    | MFP2  | EBI high byte write enable output pin     |
|        |              |         | USCI1_DAT1   | I/O  | MFP4  | USCI1 data 1 pin.                         |
|        |              |         | UART1_RXD    | I    | MFP6  | UART1 data receiver input pin.            |
|        |              |         | SD1_CLK      | O    | MFP7  | SD/SDIO1 clock output pin                 |
|        |              |         | EBI_nCS1     | O    | MFP8  | EBI chip select 1 output pin.             |
|        |              |         | BPWM1_CH5    | I/O  | MFP10 | BPWM1 channel 5 output/capture input.     |
|        |              |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.                  |
|        |              |         | EPWM1_CH5    | I/O  | MFP12 | EPWM1 channel 5 output/capture input.     |
|        |              |         | INT4         | I    | MFP13 | External interrupt 4 input pin.           |
|        |              |         | USB_VBUS_EN  | O    | MFP14 | USB external VBUS regulator enable pin.   |
|        |              |         | ACMP1_O      | O    | MFP15 | Analog comparator 1 output pin.           |

## 4.2.5 M485 Series Pin Description

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|--------|--------|--------|---------|------------|------|-------|-----------------------------------------------|
| 1      | 1      | 2      | 1       | PB.5       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EADC0_CH5  | A    | MFP1  | EADC0 channel 5 analog input.                 |
|        |        |        |         | ACMP1_N    | A    | MFP1  | Analog comparator 1 negative input pin.       |
|        |        |        |         | EBI_ADR0   | O    | MFP2  | EBI address bus bit 0.                        |
|        |        |        |         | SD0_DAT3   | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|        |        |        |         | SPI1_MISO  | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |        |        |         | I2C0_SCL   | I/O  | MFP6  | I2C0 clock pin.                               |
|        |        |        |         | UART5_TXD  | O    | MFP7  | UART5 data transmitter output pin.            |
|        |        |        |         | USCI1_CTL0 | I/O  | MFP8  | USCI1 control 0 pin.                          |
|        |        |        |         | SC0_CLK    | O    | MFP9  | Smart Card 0 clock pin.                       |
|        |        |        |         | I2S0_BCLK  | O    | MFP10 | I2S0 bit clock output pin.                    |
|        |        |        |         | EPWM0_CH0  | I/O  | MFP11 | EPWM0 channel 0 output/capture input.         |
|        |        |        |         | TM0        | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |        |        |         | INT0       | I    | MFP15 | External interrupt 0 input pin.               |
| 2      | 2      | 3      | 2       | PB.4       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EADC0_CH4  | A    | MFP1  | EADC0 channel 4 analog input.                 |
|        |        |        |         | ACMP1_P1   | A    | MFP1  | Analog comparator 1 positive input 1 pin.     |
|        |        |        |         | EBI_ADR1   | O    | MFP2  | EBI address bus bit 1.                        |
|        |        |        |         | SD0_DAT2   | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|        |        |        |         | SPI1_MOSI  | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |        |        |         | I2C0_SDA   | I/O  | MFP6  | I2C0 data input/output pin.                   |
|        |        |        |         | UART5_RXD  | I    | MFP7  | UART5 data receiver input pin.                |
|        |        |        |         | USCI1_CTL1 | I/O  | MFP8  | USCI1 control 1 pin.                          |
|        |        |        |         | SC0_DAT    | I/O  | MFP9  | Smart Card 0 data pin.                        |
|        |        |        |         | I2S0_MCLK  | O    | MFP10 | I2S0 master clock output pin.                 |
|        |        |        |         | EPWM0_CH1  | I/O  | MFP11 | EPWM0 channel 1 output/capture input.         |
|        |        |        |         | TM1        | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
|        |        |        |         | INT1       | I    | MFP15 | External interrupt 1 input pin.               |
| 3      | 3      | 4      | 3       | PB.3       | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EADC0_CH3  | A    | MFP1  | EADC0 channel 3 analog input.                 |
|        |        |        |         | ACMP0_N    | A    | MFP1  | Analog comparator 0 negative input pin.       |
|        |        |        |         | EBI_ADR2   | O    | MFP2  | EBI address bus bit 2.                        |
|        |        |        |         | SD0_DAT1   | I/O  | MFP3  | SD/SDIO0 data line bit 1.                     |

| 32 Pin           | 48 Pin | 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                   |
|------------------|--------|--------|---------|------------|------|-------|-----------------------------------------------|
| 4<br>4<br>5<br>4 | 5      | 5      | 4       | SPI1_CLK   | I/O  | MFP5  | SPI1 serial clock pin.                        |
|                  |        |        |         | UART1_TXD  | O    | MFP6  | UART1 data transmitter output pin.            |
|                  |        |        |         | UART5_nRTS | O    | MFP7  | UART5 request to Send output pin.             |
|                  |        |        |         | USCI1_DAT1 | I/O  | MFP8  | USCI1 data 1 pin.                             |
|                  |        |        |         | SC0_RST    | O    | MFP9  | Smart Card 0 reset pin.                       |
|                  |        |        |         | I2S0_DI    | I    | MFP10 | I2S0 data input pin.                          |
|                  |        |        |         | EPWM0_CH2  | I/O  | MFP11 | EPWM0 channel 2 output/capture input.         |
|                  |        |        |         | TM2        | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|                  |        |        |         | INT2       | I    | MFP15 | External interrupt 2 input pin.               |
|                  |        |        |         | PB.2       | I/O  | MFP0  | General purpose digital I/O pin.              |
|                  |        |        |         | EADC0_CH2  | A    | MFP1  | EADC0 channel 2 analog input.                 |
|                  |        |        |         | ACMP0_P1   | A    | MFP1  | Analog comparator 0 positive input 1 pin.     |
|                  |        |        |         | OPA0_O     | A    | MFP1  | Operational amplifier 0 output pin.           |
|                  |        |        |         | EBI_ADR3   | O    | MFP2  | EBI address bus bit 3.                        |
|                  |        |        |         | SD0_DAT0   | I/O  | MFP3  | SD/SDIO0 data line bit 0.                     |
|                  |        |        |         | SPI1_SS    | I/O  | MFP5  | SPI1 slave select pin.                        |
|                  |        |        |         | UART1_RXD  | I    | MFP6  | UART1 data receiver input pin.                |
|                  |        |        |         | UART5_nCTS | I    | MFP7  | UART5 clear to Send input pin.                |
|                  |        |        |         | USCI1_DAT0 | I/O  | MFP8  | USCI1 data 0 pin.                             |
|                  |        |        |         | SC0_PWR    | O    | MFP9  | Smart Card 0 power pin.                       |
|                  |        |        |         | I2S0_DO    | O    | MFP10 | I2S0 data output pin.                         |
|                  |        |        |         | EPWM0_CH3  | I/O  | MFP11 | EPWM0 channel 3 output/capture input.         |
|                  |        |        |         | TM3        | I/O  | MFP14 | Timer3 event counter input/toggle output pin. |
|                  |        |        |         | INT3       | I    | MFP15 | External interrupt 3 input pin.               |
| 5                | 6      | 6      | 6       | PC.12      | I/O  | MFP0  | General purpose digital I/O pin.              |
|                  |        |        |         | EBI_ADR4   | O    | MFP2  | EBI address bus bit 4.                        |
|                  |        |        |         | UART0_TXD  | O    | MFP3  | UART0 data transmitter output pin.            |
|                  |        |        |         | I2C0_SCL   | I/O  | MFP4  | I2C0 clock pin.                               |
|                  |        |        |         | SPI3_MISO  | I/O  | MFP6  | SPI3 MISO (Master In, Slave Out) pin.         |
|                  |        |        |         | SC0_nCD    | I    | MFP9  | Smart Card 0 card detect pin.                 |
|                  |        |        |         | ECAP1_IC2  | I    | MFP11 | Enhanced capture unit 1 input 2 pin.          |
|                  |        |        |         | EPWM1_CH0  | I/O  | MFP12 | EPWM1 channel 0 output/capture input.         |
|                  |        |        |         | ACMP0_O    | O    | MFP14 | Analog comparator 0 output pin.               |
|                  |        |        |         | PC.11      | I/O  | MFP0  | General purpose digital I/O pin.              |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | EBI_ADR5     | O    | MFP2  | EBI address bus bit 5.                      |
|        |        |        |         | UART0_RXD    | I    | MFP3  | UART0 data receiver input pin.              |
|        |        |        |         | I2C0_SDA     | I/O  | MFP4  | I2C0 data input/output pin.                 |
|        |        |        |         | SPI3_MOSI    | I/O  | MFP6  | SPI3 MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | ECAP1_IC1    | I    | MFP11 | Enhanced capture unit 1 input 1 pin.        |
|        |        |        |         | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        |        |        |         | ACMP1_O      | O    | MFP14 | Analog comparator 1 output pin.             |
|        |        |        | 7       | PC.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_ADR6     | O    | MFP2  | EBI address bus bit 6.                      |
|        |        |        |         | SPI3_CLK     | I/O  | MFP6  | SPI3 serial clock pin.                      |
|        |        |        |         | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.          |
|        |        |        |         | CAN1_TXD     | O    | MFP9  | CAN1 bus transmitter output.                |
|        |        |        |         | ECAP1_IC0    | I    | MFP11 | Enhanced capture unit 1 input 0 pin.        |
|        |        |        |         | EPWM1_CH2    | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        |        |        | 8       | PC.9         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_ADR7     | O    | MFP2  | EBI address bus bit 7.                      |
|        |        |        |         | SPI3_SS      | I/O  | MFP6  | SPI3 slave select pin.                      |
|        |        |        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.              |
|        |        |        |         | CAN1_RXD     | I    | MFP9  | CAN1 bus receiver input.                    |
|        |        |        |         | EPWM1_CH3    | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        |        |        | 9       | PB.1         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EADC0_CH1    | A    | MFP1  | EADC0 channel 1 analog input.               |
|        |        |        |         | OPA0_N       | A    | MFP1  | Operational amplifier 0 negative input pin. |
|        |        |        |         | EBI_ADR8     | O    | MFP2  | EBI address bus bit 8.                      |
|        |        |        |         | SD0_CLK      | O    | MFP3  | SD/SDIO0 clock output pin                   |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin            |
|        |        |        |         | SPI3_I2SMCLK | I/O  | MFP6  | SPI3 I2S master clock output pin            |
|        |        |        |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.          |
|        |        |        |         | USCI1_CLK    | I/O  | MFP8  | USCI1 clock pin.                            |
|        |        |        |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |        |        |         | I2S0_LRCK    | O    | MFP10 | I2S0 left right channel clock output pin.   |
|        |        |        |         | EPWM0_CH4    | I/O  | MFP11 | EPWM0 channel 4 output/capture input.       |
|        |        |        |         | EPWM1_CH4    | I/O  | MFP12 | EPWM1 channel 4 output/capture input.       |
|        |        |        |         | EPWM0_BRAKE0 | I    | MFP13 | EPWM0 Brake 0 input pin.                    |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
| 6      | 6      | 7      | 10      | PB.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EADC0_CH0       | A    | MFP1  | EADC0 channel 0 analog input.                                                   |
|        |        |        |         | OPA0_P          | A    | MFP1  | Operational amplifier 0 positive input pin.                                     |
|        |        |        |         | EBI_ADR9        | O    | MFP2  | EBI address bus bit 9.                                                          |
|        |        |        |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                   |
|        |        |        |         | UART2_RXD       | I    | MFP7  | UART2 data receiver input pin.                                                  |
|        |        |        |         | SPI0_I2SMCLK    | I/O  | MFP8  | SPI0 I2S master clock output pin                                                |
|        |        |        |         | I2C1_SDA        | I/O  | MFP9  | I2C1 data input/output pin.                                                     |
|        |        |        |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |        |        |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |        |        |         | EPWM0_BRAKE1    | I    | MFP13 | EPWM0 Brake 1 input pin.                                                        |
|        |        |        | 11      | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        | 12      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 7      | 8      | 13     | 13      | PA.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | ACMP0_P0        | A    | MFP1  | Analog comparator 0 positive input 0 pin.                                       |
|        |        |        |         | EBI_nRD         | O    | MFP2  | EBI read enable output pin.                                                     |
|        |        |        |         | SC2_PWR         | O    | MFP3  | Smart Card 2 power pin.                                                         |
|        |        |        |         | SPI2_SS         | I/O  | MFP4  | SPI2 slave select pin.                                                          |
|        |        |        |         | SD1_DAT3        | I/O  | MFP5  | SD/SDIO1 data line bit 3.                                                       |
|        |        |        |         | USCI0_CLK       | I/O  | MFP6  | USCI0 clock pin.                                                                |
|        |        |        |         | I2C2_SCL        | I/O  | MFP7  | I2C2 clock pin.                                                                 |
|        |        |        |         | BPWM0_CH0       | I/O  | MFP9  | BPWM0 channel 0 output/capture input.                                           |
|        |        |        |         | EPWM0_SYNC_OUT  | O    | MFP10 | EPWM0 counter synchronous trigger output pin.                                   |
|        |        |        |         | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
|        |        |        |         | DAC1_ST         | I    | MFP14 | DAC1 external trigger input.                                                    |
| 8      | 9      | 14     | 14      | PA.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | ACMP1_P0        | A    | MFP1  | Analog comparator 1 positive input 0 pin.                                       |
|        |        |        |         | OPA1_O          | A    | MFP1  | Operational amplifier 1 output pin.                                             |
|        |        |        |         | EBI_nWR         | O    | MFP2  | EBI write enable output pin.                                                    |
|        |        |        |         | SC2_RST         | O    | MFP3  | Smart Card 2 reset pin.                                                         |
|        |        |        |         | SPI2_CLK        | I/O  | MFP4  | SPI2 serial clock pin.                                                          |
|        |        |        |         | SD1_DAT2        | I/O  | MFP5  | SD/SDIO1 data line bit 2.                                                       |
|        |        |        |         | USCI0_DAT0      | I/O  | MFP6  | USCI0 data 0 pin.                                                               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name   | Type | MFP   | Description                                      |
|--------|--------|--------|---------|------------|------|-------|--------------------------------------------------|
|        |        |        |         | I2C2_SDA   | I/O  | MFP7  | I2C2 data input/output pin.                      |
|        |        |        |         | BPWM0_CH1  | I/O  | MFP9  | BPWM0 channel 1 output/capture input.            |
|        |        |        |         | QEI1_INDEX | I    | MFP10 | Quadrature encoder 1 index input                 |
|        |        |        |         | ECAPO_IC0  | I    | MFP11 | Enhanced capture unit 0 input 0 pin.             |
|        |        |        |         | TM1_EXT    | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |        |        |         | DAC0_ST    | I    | MFP14 | DAC0 external trigger input.                     |
|        | 9      | 10     | 15      | PA.9       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | OPA1_N     | A    | MFP1  | Operational amplifier 1 negative input pin.      |
|        |        |        |         | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.                   |
|        |        |        |         | SC2_DAT    | I/O  | MFP3  | Smart Card 2 data pin.                           |
|        |        |        |         | SPI2_MISO  | I/O  | MFP4  | SPI2 MISO (Master In, Slave Out) pin.            |
|        |        |        |         | SD1_DAT1   | I/O  | MFP5  | SD/SDIO1 data line bit 1.                        |
|        |        |        |         | USCI0_DAT1 | I/O  | MFP6  | USCI0 data 1 pin.                                |
|        |        |        |         | UART1_TXD  | O    | MFP7  | UART1 data transmitter output pin.               |
|        |        |        |         | BPWM0_CH2  | I/O  | MFP9  | BPWM0 channel 2 output/capture input.            |
|        |        |        |         | QEI1_A     | I    | MFP10 | Quadrature encoder 1 phase A input               |
|        |        |        |         | ECAPO_IC1  | I    | MFP11 | Enhanced capture unit 0 input 1 pin.             |
|        |        |        |         | TM2_EXT    | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|        | 10     | 11     | 16      | PA.8       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | OPA1_P     | A    | MFP1  | Operational amplifier 1 positive input pin.      |
|        |        |        |         | EBI_ALE    | O    | MFP2  | EBI address latch enable output pin.             |
|        |        |        |         | SC2_CLK    | O    | MFP3  | Smart Card 2 clock pin.                          |
|        |        |        |         | SPI2_MOSI  | I/O  | MFP4  | SPI2 MOSI (Master Out, Slave In) pin.            |
|        |        |        |         | SD1_DAT0   | I/O  | MFP5  | SD/SDIO1 data line bit 0.                        |
|        |        |        |         | USCI0_CTL1 | I/O  | MFP6  | USCI0 control 1 pin.                             |
|        |        |        |         | UART1_RXD  | I    | MFP7  | UART1 data receiver input pin.                   |
|        |        |        |         | BPWM0_CH3  | I/O  | MFP9  | BPWM0 channel 3 output/capture input.            |
|        |        |        |         | QEI1_B     | I    | MFP10 | Quadrature encoder 1 phase B input               |
|        |        |        |         | ECAPO_IC2  | I    | MFP11 | Enhanced capture unit 0 input 2 pin.             |
|        |        |        |         | TM3_EXT    | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
|        |        |        |         | INT4       | I    | MFP15 | External interrupt 4 input pin.                  |
|        |        |        | 17      | PC.13      | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | EBI_ADR10  | O    | MFP2  | EBI address bus bit 10.                          |
|        |        |        |         | SC2_nCD    | I    | MFP3  | Smart Card 2 card detect pin.                    |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | SPI2_I2SMCLK | I/O  | MFP4  | SPI2 I2S master clock output pin            |
|        |        |        |         | CAN1_TXD     | O    | MFP5  | CAN1 bus transmitter output.                |
|        |        |        |         | USCI0_CTL0   | I/O  | MFP6  | USCI0 control 0 pin.                        |
|        |        |        |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.          |
|        |        |        |         | BPWM0_CH4    | I/O  | MFP9  | BPWM0 channel 4 output/capture input.       |
|        |        |        |         | CLKO         | O    | MFP13 | Clock Out                                   |
|        |        |        |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.               |
|        |        |        | 18      | PD.12        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | OPA2_O       | A    | MFP1  | Operational amplifier 2 output pin.         |
|        |        |        |         | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.               |
|        |        |        |         | CAN1_RXD     | I    | MFP5  | CAN1 bus receiver input.                    |
|        |        |        |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.              |
|        |        |        |         | BPWM0_CH5    | I/O  | MFP9  | BPWM0 channel 5 output/capture input.       |
|        |        |        |         | QEIO_INDEX   | I    | MFP10 | Quadrature encoder 0 index input            |
|        |        |        |         | CLKO         | O    | MFP13 | Clock Out                                   |
|        |        |        |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.               |
|        |        |        |         | INT5         | I    | MFP15 | External interrupt 5 input pin.             |
|        |        |        | 19      | PD.11        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | OPA2_N       | A    | MFP1  | Operational amplifier 2 negative input pin. |
|        |        |        |         | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.               |
|        |        |        |         | UART1_TXD    | O    | MFP3  | UART1 data transmitter output pin.          |
|        |        |        |         | CAN0_RXD     | O    | MFP4  | CAN0 bus transmitter output.                |
|        |        |        |         | QEIO_A       | I    | MFP10 | Quadrature encoder 0 phase A input          |
|        |        |        |         | INT6         | I    | MFP15 | External interrupt 6 input pin.             |
|        |        |        | 20      | PD.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | OPA2_P       | A    | MFP1  | Operational amplifier 2 positive input pin. |
|        |        |        |         | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.               |
|        |        |        |         | UART1_RXD    | I    | MFP3  | UART1 data receiver input pin.              |
|        |        |        |         | CAN0_RXD     | I    | MFP4  | CAN0 bus receiver input.                    |
|        |        |        |         | QEIO_B       | I    | MFP10 | Quadrature encoder 0 phase B input          |
|        |        |        |         | INT7         | I    | MFP15 | External interrupt 7 input pin.             |
|        |        |        | 21      | PG.2         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.                     |
|        |        |        |         | SPI2_SS      | I/O  | MFP3  | SPI2 slave select pin.                      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------|--------|---------|--------------|------|-------|-----------------------------------------------|
|        |        |        |         | I2C0_SMBAL   | O    | MFP4  | I2C0 SMBus SMBALTER pin                       |
|        |        |        |         | I2C1_SCL     | I/O  | MFP5  | I2C1 clock pin.                               |
|        |        |        |         | TM0          | I/O  | MFP13 | Timer0 event counter input/toggle output pin. |
|        |        |        | 22      | PG.3         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.                       |
|        |        |        |         | SPI2_CLK     | I/O  | MFP3  | SPI2 serial clock pin.                        |
|        |        |        |         | I2C0_SMBSUS  | O    | MFP4  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)     |
|        |        |        |         | I2C1_SDA     | I/O  | MFP5  | I2C1 data input/output pin.                   |
|        |        |        |         | TM1          | I/O  | MFP13 | Timer1 event counter input/toggle output pin. |
|        |        |        | 23      | PG.4         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.                       |
|        |        |        |         | SPI2_MISO    | I/O  | MFP3  | SPI2 MISO (Master In, Slave Out) pin.         |
|        |        |        |         | TM2          | I/O  | MFP13 | Timer2 event counter input/toggle output pin. |
|        |        |        | 24      | PF.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.                       |
|        |        |        |         | SPI2_MOSI    | I/O  | MFP3  | SPI2 MOSI (Master Out, Slave In) pin.         |
|        |        |        |         | TAMPER5      | I/O  | MFP10 | TAMPER detector loop pin 5.                   |
|        |        |        |         | TM3          | I/O  | MFP13 | Timer3 event counter input/toggle output pin. |
|        |        |        | 25      | PF.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |        |        |         | SC0_nCD      | I    | MFP3  | Smart Card 0 card detect pin.                 |
|        |        |        |         | I2S0_BCLK    | O    | MFP4  | I2S0 bit clock output pin.                    |
|        |        |        |         | SPI0_I2SMCLK | I/O  | MFP5  | SPI0 I2S master clock output pin              |
|        |        |        |         | TAMPER4      | I/O  | MFP10 | TAMPER detector loop pin 4.                   |
|        |        |        | 26      | PF.9         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |        |        |         | SC0_PWR      | O    | MFP3  | Smart Card 0 power pin.                       |
|        |        |        |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.                 |
|        |        |        |         | SPI0_SS      | I/O  | MFP5  | SPI0 slave select pin.                        |
|        |        |        |         | TAMPER3      | I/O  | MFP10 | TAMPER detector loop pin 3.                   |
|        |        |        | 27      | PF.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR17    | O    | MFP2  | EBI address bus bit 17.                       |
|        |        |        |         | SC0_RST      | O    | MFP3  | Smart Card 0 reset pin.                       |
|        |        |        |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                          |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type           | MFP   | Description                                                                     |                                               |
|--------|--------|--------|---------|-----------------|----------------|-------|---------------------------------------------------------------------------------|-----------------------------------------------|
|        |        |        |         | SPI0_CLK        | I/O            | MFP5  | SPI0 serial clock pin.                                                          |                                               |
|        |        |        |         | TAMPER2         | I/O            | MFP10 | TAMPER detector loop pin 2.                                                     |                                               |
|        |        | 28     |         | PF.7            | I/O            | MFP0  | General purpose digital I/O pin.                                                |                                               |
|        |        |        |         | EBI_ADR18       | O              | MFP2  | EBI address bus bit 18.                                                         |                                               |
|        |        |        |         | SC0_DAT         | I/O            | MFP3  | Smart Card 0 data pin.                                                          |                                               |
|        |        |        |         | I2S0_DO         | O              | MFP4  | I2S0 data output pin.                                                           |                                               |
|        |        |        |         | SPI0_MISO       | I/O            | MFP5  | SPI0 MISO (Master In, Slave Out) pin.                                           |                                               |
|        |        |        |         | UART4_TXD       | O              | MFP6  | UART4 data transmitter output pin.                                              |                                               |
|        |        |        |         | TAMPER1         | I/O            | MFP10 | TAMPER detector loop pin 1.                                                     |                                               |
|        |        | 12     | 29      | PF.6            | I/O            | MFP0  | General purpose digital I/O pin.                                                |                                               |
|        |        |        |         | EBI_ADR19       | O              | MFP2  | EBI address bus bit 19.                                                         |                                               |
|        |        |        |         | SC0_CLK         | O              | MFP3  | Smart Card 0 clock pin.                                                         |                                               |
|        |        |        |         | I2S0_LRCK       | O              | MFP4  | I2S0 left right channel clock output pin.                                       |                                               |
|        |        |        |         | SPI0_MOSI       | I/O            | MFP5  | SPI0 MOSI (Master Out, Slave In) pin.                                           |                                               |
|        |        |        |         | UART4_RXD       | I              | MFP6  | UART4 data receiver input pin.                                                  |                                               |
|        |        |        |         | EBI_nCS0        | O              | MFP7  | EBI chip select 0 output pin.                                                   |                                               |
|        |        |        |         | TAMPER0         | I/O            | MFP10 | TAMPER detector loop pin 0.                                                     |                                               |
|        |        | 13     | 30      | V <sub>DD</sub> | P              | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |                                               |
|        |        | 11     | 14      | 31              | PF.5           | I/O   | MFP0                                                                            | General purpose digital I/O pin.              |
|        |        |        |         |                 | UART2_RXD      | I     | MFP2                                                                            | UART2 data receiver input pin.                |
|        |        |        |         |                 | UART2_nCTS     | I     | MFP4                                                                            | UART2 clear to Send input pin.                |
|        |        |        |         |                 | BPWM0_CH4      | I/O   | MFP8                                                                            | BPWM0 channel 4 output/capture input.         |
|        |        |        |         |                 | EPWM0_SYNC_OUT | O     | MFP9                                                                            | EPWM0 counter synchronous trigger output pin. |
|        |        |        |         |                 | X32_IN         | I     | MFP10                                                                           | External 32.768 kHz crystal input pin.        |
|        |        |        |         |                 | EADC0_ST       | I     | MFP11                                                                           | EADC0 external trigger input.                 |
|        |        | 12     | 15      | 32              | PF.4           | I/O   | MFP0                                                                            | General purpose digital I/O pin.              |
|        |        |        |         |                 | UART2_TXD      | O     | MFP2                                                                            | UART2 data transmitter output pin.            |
|        |        |        |         |                 | UART2_nRTS     | O     | MFP4                                                                            | UART2 request to Send output pin.             |
|        |        |        |         |                 | BPWM0_CH5      | I/O   | MFP8                                                                            | BPWM0 channel 5 output/capture input.         |
|        |        |        |         |                 | X32_OUT        | O     | MFP10                                                                           | External 32.768 kHz crystal output pin.       |
|        |        |        | 33      | PH.4            | I/O            | MFP0  | General purpose digital I/O pin.                                                |                                               |
|        |        |        |         | EBI_ADR3        | O              | MFP2  | EBI address bus bit 3.                                                          |                                               |
|        |        |        |         | SPI1_MISO       | I/O            | MFP3  | SPI1 MISO (Master In, Slave Out) pin.                                           |                                               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        | 34      | PH.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR2        | O    | MFP2  | EBI address bus bit 2.                                                          |
|        |        |        |         | SPI1_MOSI       | I/O  | MFP3  | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|        |        |        | 35      | PH.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR1        | O    | MFP2  | EBI address bus bit 1.                                                          |
|        |        |        |         | SPI1_CLK        | I/O  | MFP3  | SPI1 serial clock pin.                                                          |
|        |        |        | 36      | PH.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR0        | O    | MFP2  | EBI address bus bit 0.                                                          |
|        |        |        |         | SPI1_SS         | I/O  | MFP3  | SPI1 slave select pin.                                                          |
| 9      | 13     | 16     | 37      | PF.3            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_nCS0        | O    | MFP2  | EBI chip select 0 output pin.                                                   |
|        |        |        |         | UART0_TXD       | O    | MFP3  | UART0 data transmitter output pin.                                              |
|        |        |        |         | I2C0_SCL        | I/O  | MFP4  | I2C0 clock pin.                                                                 |
|        |        |        |         | XT1_IN          | I    | MFP10 | External 4~24 MHz (high speed) crystal input pin.                               |
|        |        |        |         | BPWM1_CH0       | I/O  | MFP11 | BPWM1 channel 0 output/capture input.                                           |
| 10     | 14     | 17     | 38      | PF.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_nCS1        | O    | MFP2  | EBI chip select 1 output pin.                                                   |
|        |        |        |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.                                                  |
|        |        |        |         | I2C0_SDA        | I/O  | MFP4  | I2C0 data input/output pin.                                                     |
|        |        |        |         | QSPI0_CLK       | I/O  | MFP5  | Quad SPI0 serial clock pin.                                                     |
|        |        |        |         | XT1_OUT         | O    | MFP10 | External 4~24 MHz (high speed) crystal output pin.                              |
|        |        |        |         | BPWM1_CH1       | I/O  | MFP11 | BPWM1 channel 1 output/capture input.                                           |
|        |        |        | 39      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        |         | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 41      | PE.8            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ADR10       | O    | MFP2  | EBI address bus bit 10.                                                         |
|        |        |        |         | I2S0_BCLK       | O    | MFP4  | I2S0 bit clock output pin.                                                      |
|        |        |        |         | SPI2_CLK        | I/O  | MFP5  | SPI2 serial clock pin.                                                          |
|        |        |        |         | USCI1_CTL1      | I/O  | MFP6  | USCI1 control 1 pin.                                                            |
|        |        |        |         | UART2_TXD       | O    | MFP7  | UART2 data transmitter output pin.                                              |
|        |        |        |         | EPWM0_CH0       | I/O  | MFP10 | EPWM0 channel 0 output/capture input.                                           |
|        |        |        |         | EPWM0_BRAKE0    | I    | MFP11 | EPWM0 Brake 0 input pin.                                                        |
|        |        |        |         | ECAPO_IC0       | I    | MFP12 | Enhanced capture unit 0 input 0 pin.                                            |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------|
|        |        |        |         | TRACE_CLK    | O    | MFP14 | ETM Trace Clock output pin            |
|        |        |        |         | PE.9         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.               |
|        |        |        |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.         |
|        |        |        |         | SPI2_MISO    | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin. |
|        |        |        |         | USCI1_CTL0   | I/O  | MFP6  | USCI1 control 0 pin.                  |
|        |        |        |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.        |
|        |        |        |         | EPWM0_CH1    | I/O  | MFP10 | EPWM0 channel 1 output/capture input. |
|        |        |        |         | EPWM0_BRAKE1 | I    | MFP11 | EPWM0 Brake 1 input pin.              |
|        |        |        |         | ECAP0_IC1    | I    | MFP12 | Enhanced capture unit 0 input 1 pin.  |
|        |        |        |         | TRACE_DATA0  | O    | MFP14 | ETM Trace Data 0 output pin           |
|        |        |        |         | PE.10        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.               |
|        |        |        |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                  |
|        |        |        |         | SPI2_MOSI    | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin. |
|        |        |        |         | USCI1_DAT0   | I/O  | MFP6  | USCI1 data 0 pin.                     |
|        |        |        |         | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.    |
|        |        |        |         | EPWM0_CH2    | I/O  | MFP10 | EPWM0 channel 2 output/capture input. |
|        |        |        |         | EPWM1_BRAKE0 | I    | MFP11 | EPWM1 Brake 0 input pin.              |
|        |        |        |         | ECAP0_IC2    | I    | MFP12 | Enhanced capture unit 0 input 2 pin.  |
|        |        |        |         | TRACE_DATA1  | O    | MFP14 | ETM Trace Data 1 output pin           |
|        |        |        |         | PE.11        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.               |
|        |        |        |         | I2S0_DO      | O    | MFP4  | I2S0 data output pin.                 |
|        |        |        |         | SPI2_SS      | I/O  | MFP5  | SPI2 slave select pin.                |
|        |        |        |         | USCI1_DAT1   | I/O  | MFP6  | USCI1 data 1 pin.                     |
|        |        |        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.        |
|        |        |        |         | UART1_nCTS   | I    | MFP8  | UART1 clear to Send input pin.        |
|        |        |        |         | EPWM0_CH3    | I/O  | MFP10 | EPWM0 channel 3 output/capture input. |
|        |        |        |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.              |
|        |        |        |         | ECAP1_IC2    | I    | MFP13 | Enhanced capture unit 1 input 2 pin.  |
|        |        |        |         | TRACE_DATA2  | O    | MFP14 | ETM Trace Data 2 output pin           |
|        |        |        |         | PE.12        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|--------|--------|---------|--------------|------|-------|-----------------------------------------------|
|        |        |        |         | I2S0_LRCK    | O    | MFP4  | I2S0 left right channel clock output pin.     |
|        |        |        |         | SPI2_I2SMCLK | I/O  | MFP5  | SPI2 I2S master clock output pin              |
|        |        |        |         | USCI1_CLK    | I/O  | MFP6  | USCI1 clock pin.                              |
|        |        |        |         | UART1_nRTS   | O    | MFP8  | UART1 request to Send output pin.             |
|        |        |        |         | EPWM0_CH4    | I/O  | MFP10 | EPWM0 channel 4 output/capture input.         |
|        |        |        |         | ECAP1_IC1    | I    | MFP13 | Enhanced capture unit 1 input 1 pin.          |
|        |        |        |         | TRACE_DATA3  | O    | MFP14 | ETM Trace Data 3 output pin                   |
|        |        |        | 46      | PE.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |        |        |         | I2C0_SCL     | I/O  | MFP4  | I2C0 clock pin.                               |
|        |        |        |         | UART4_nRTS   | O    | MFP5  | UART4 request to Send output pin.             |
|        |        |        |         | UART1_TXD    | O    | MFP8  | UART1 data transmitter output pin.            |
|        |        |        |         | EPWM0_CH5    | I/O  | MFP10 | EPWM0 channel 5 output/capture input.         |
|        |        |        |         | EPWM1_CH0    | I/O  | MFP11 | EPWM1 channel 0 output/capture input.         |
|        |        |        |         | BPWM1_CH5    | I/O  | MFP12 | BPWM1 channel 5 output/capture input.         |
|        |        |        |         | ECAP1_IC0    | I    | MFP13 | Enhanced capture unit 1 input 0 pin.          |
|        |        |        | 47      | PC.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |        |        |         | I2C0_SDA     | I/O  | MFP4  | I2C0 data input/output pin.                   |
|        |        |        |         | UART4_nCTS   | I    | MFP5  | UART4 clear to Send input pin.                |
|        |        |        |         | UART1_RXD    | I    | MFP8  | UART1 data receiver input pin.                |
|        |        |        |         | EPWM1_CH1    | I/O  | MFP11 | EPWM1 channel 1 output/capture input.         |
|        |        |        |         | BPWM1_CH4    | I/O  | MFP12 | BPWM1 channel 4 output/capture input.         |
|        |        | 48     | 18      | PC.7         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |        |        |         | EBI_AD9      | I/O  | MFP2  | EBI address/data bus bit 9.                   |
|        |        |        |         | SPI1_MISO    | I/O  | MFP4  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |        |        |         | UART4_TXD    | O    | MFP5  | UART4 data transmitter output pin.            |
|        |        |        |         | SC2_PWR      | O    | MFP6  | Smart Card 2 power pin.                       |
|        |        |        |         | UART0_nCTS   | I    | MFP7  | UART0 clear to Send input pin.                |
|        |        |        |         | I2C1_SMBAL   | O    | MFP8  | I2C1 SMBus SMBALTER pin                       |
|        |        |        |         | EPWM1_CH2    | I/O  | MFP11 | EPWM1 channel 2 output/capture input.         |
|        |        |        |         | BPWM1_CH0    | I/O  | MFP12 | BPWM1 channel 0 output/capture input.         |
|        |        |        |         | TM0          | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |        |        |         | INT3         | I    | MFP15 | External interrupt 3 input pin.               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type       | MFP   | Description                                   |                                               |
|--------|--------|--------|---------|-------------|------------|-------|-----------------------------------------------|-----------------------------------------------|
|        |        | 19     | 49      | PC.6        | I/O        | MFP0  | General purpose digital I/O pin.              |                                               |
|        |        |        |         | EBI_AD8     | I/O        | MFP2  | EBI address/data bus bit 8.                   |                                               |
|        |        |        |         | SPI1_MOSI   | I/O        | MFP4  | SPI1 MOSI (Master Out, Slave In) pin.         |                                               |
|        |        |        |         | UART4_RXD   | I          | MFP5  | UART4 data receiver input pin.                |                                               |
|        |        |        |         | SC2_RST     | O          | MFP6  | Smart Card 2 reset pin.                       |                                               |
|        |        |        |         | UART0_nRTS  | O          | MFP7  | UART0 request to Send output pin.             |                                               |
|        |        |        |         | I2C1_SMBSUS | O          | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)     |                                               |
|        |        |        |         | EPWM1_CH3   | I/O        | MFP11 | EPWM1 channel 3 output/capture input.         |                                               |
|        |        |        |         | BPWM1_CH1   | I/O        | MFP12 | BPWM1 channel 1 output/capture input.         |                                               |
|        |        |        |         | TM1         | I/O        | MFP14 | Timer1 event counter input/toggle output pin. |                                               |
|        |        | 15     | 20      | 50          | PA.7       | I/O   | MFP0                                          | General purpose digital I/O pin.              |
|        |        |        |         |             | EBI_AD7    | I/O   | MFP2                                          | EBI address/data bus bit 7.                   |
|        |        |        |         |             | SPI1_CLK   | I/O   | MFP4                                          | SPI1 serial clock pin.                        |
|        |        |        |         |             | SC2_DAT    | I/O   | MFP6                                          | Smart Card 2 data pin.                        |
|        |        |        |         |             | UART0_TXD  | O     | MFP7                                          | UART0 data transmitter output pin.            |
|        |        |        |         |             | I2C1_SCL   | I/O   | MFP8                                          | I2C1 clock pin.                               |
|        |        |        |         |             | EPWM1_CH4  | I/O   | MFP11                                         | EPWM1 channel 4 output/capture input.         |
|        |        |        |         |             | BPWM1_CH2  | I/O   | MFP12                                         | BPWM1 channel 2 output/capture input.         |
|        |        |        |         |             | ACMP0_WLAT | I     | MFP13                                         | Analog comparator 0 window latch input pin    |
|        |        |        |         |             | TM2        | I/O   | MFP14                                         | Timer2 event counter input/toggle output pin. |
|        |        | 16     | 21      | 51          | PA.6       | I/O   | MFP0                                          | General purpose digital I/O pin.              |
|        |        |        |         |             | EBI_AD6    | I/O   | MFP2                                          | EBI address/data bus bit 6.                   |
|        |        |        |         |             | SPI1_SS    | I/O   | MFP4                                          | SPI1 slave select pin.                        |
|        |        |        |         |             | SD1_nCD    | I     | MFP5                                          | SD/SDIO1 card detect input pin                |
|        |        |        |         |             | SC2_CLK    | O     | MFP6                                          | Smart Card 2 clock pin.                       |
|        |        |        |         |             | UART0_RXD  | I     | MFP7                                          | UART0 data receiver input pin.                |
|        |        |        |         |             | I2C1_SDA   | I/O   | MFP8                                          | I2C1 data input/output pin.                   |
|        |        |        |         |             | EPWM1_CH5  | I/O   | MFP11                                         | EPWM1 channel 5 output/capture input.         |
|        |        |        |         |             | BPWM1_CH3  | I/O   | MFP12                                         | BPWM1 channel 3 output/capture input.         |
|        |        |        |         |             | ACMP1_WLAT | I     | MFP13                                         | Analog comparator 1 window latch input pin    |
|        |        |        |         |             | TM3        | I/O   | MFP14                                         | Timer3 event counter input/toggle output pin. |
|        |        |        |         |             | INT0       | I     | MFP15                                         | External interrupt 0 input pin.               |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin      | Pin Name        | Type  | MFP                                         | Description                                                                     |
|--------|--------|--------|--------------|-----------------|-------|---------------------------------------------|---------------------------------------------------------------------------------|
|        |        | 22     | 52           | V <sub>SS</sub> | P     | MFP0                                        | Ground pin for digital circuit.                                                 |
|        |        | 23     | 53           | V <sub>DD</sub> | P     | MFP0                                        | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        | 24     | 54           | LDO_CAP         | A     | MFP0                                        | LDO output pin.                                                                 |
| 17     | 25     | 55     | PA.5         | I/O             | MFP0  | General purpose digital I/O pin.            |                                                                                 |
|        |        |        | SPIM_D2      | I/O             | MFP2  | SPIM data 2 pin for Quad Mode I/O.          |                                                                                 |
|        |        |        | QSPI0_MISO1  | I/O             | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |                                                                                 |
|        |        |        | SPI1_I2SMCLK | I/O             | MFP4  | SPI1 I2S master clock output pin            |                                                                                 |
|        |        |        | SD1_CMD      | I/O             | MFP5  | SD/SDIO1 command/response pin               |                                                                                 |
|        |        |        | SC2_nCD      | I               | MFP6  | Smart Card 2 card detect pin.               |                                                                                 |
|        |        |        | UART0_nCTS   | I               | MFP7  | UART0 clear to Send input pin.              |                                                                                 |
|        |        |        | UART5_TXD    | O               | MFP8  | UART5 data transmitter output pin.          |                                                                                 |
|        |        |        | I2C0_SCL     | I/O             | MFP9  | I2C0 clock pin.                             |                                                                                 |
|        |        |        | CAN0_TXD     | O               | MFP10 | CAN0 bus transmitter output.                |                                                                                 |
|        |        |        | BPWM0_CH5    | I/O             | MFP12 | BPWM0 channel 5 output/capture input.       |                                                                                 |
|        |        |        | EPWM0_CH0    | I/O             | MFP13 | EPWM0 channel 0 output/capture input.       |                                                                                 |
| 18     | 26     | 56     | PA.4         | I/O             | MFP0  | General purpose digital I/O pin.            |                                                                                 |
|        |        |        | SPIM_D3      | I/O             | MFP2  | SPIM data 3 pin for Quad Mode I/O.          |                                                                                 |
|        |        |        | QSPI0_MOSI1  | I/O             | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |                                                                                 |
|        |        |        | SPI0_I2SMCLK | I/O             | MFP4  | SPI0 I2S master clock output pin            |                                                                                 |
|        |        |        | SD1_CLK      | O               | MFP5  | SD/SDIO1 clock output pin                   |                                                                                 |
|        |        |        | SC0_nCD      | I               | MFP6  | Smart Card 0 card detect pin.               |                                                                                 |
|        |        |        | UART0_nRTS   | O               | MFP7  | UART0 request to Send output pin.           |                                                                                 |
|        |        |        | UART5_RXD    | I               | MFP8  | UART5 data receiver input pin.              |                                                                                 |
|        |        |        | I2C0_SDA     | I/O             | MFP9  | I2C0 data input/output pin.                 |                                                                                 |
|        |        |        | CAN0_RXD     | I               | MFP10 | CAN0 bus receiver input.                    |                                                                                 |
|        |        |        | BPWM0_CH4    | I/O             | MFP12 | BPWM0 channel 4 output/capture input.       |                                                                                 |
|        |        |        | EPWM0_CH1    | I/O             | MFP13 | EPWM0 channel 1 output/capture input.       |                                                                                 |
| 11     | 19     | 27     | 57           | PA.3            | I/O   | MFP0                                        | General purpose digital I/O pin.                                                |
|        |        |        |              | SPIM_SS         | I/O   | MFP2                                        | SPIM slave select pin.                                                          |
|        |        |        |              | QSPI0_SS        | I/O   | MFP3                                        | Quad SPI0 slave select pin.                                                     |
|        |        |        |              | SPI0_SS         | I/O   | MFP4                                        | SPI0 slave select pin.                                                          |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------|--------|---------|-------------|------|-------|---------------------------------------------|
|        |        |        |         | SD1_DAT3    | I/O  | MFP5  | SD/SDIO1 data line bit 3.                   |
|        |        |        |         | SC0_PWR     | O    | MFP6  | Smart Card 0 power pin.                     |
|        |        |        |         | UART4_TXD   | O    | MFP7  | UART4 data transmitter output pin.          |
|        |        |        |         | UART1_TXD   | O    | MFP8  | UART1 data transmitter output pin.          |
|        |        |        |         | I2C1_SCL    | I/O  | MFP9  | I2C1 clock pin.                             |
|        |        |        |         | BPWM0_CH3   | I/O  | MFP12 | BPWM0 channel 3 output/capture input.       |
|        |        |        |         | EPWM0_CH2   | I/O  | MFP13 | EPWM0 channel 2 output/capture input.       |
|        |        |        |         | QEI0_B      | I    | MFP14 | Quadrature encoder 0 phase B input          |
| 12     | 20     | 28     | 58      | PA.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | SPIM_CLK    | I/O  | MFP2  | SPIM serial clock pin.                      |
|        |        |        |         | QSPI0_CLK   | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |        |        |         | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                      |
|        |        |        |         | SD1_DAT2    | I/O  | MFP5  | SD/SDIO1 data line bit 2.                   |
|        |        |        |         | SC0_RST     | O    | MFP6  | Smart Card 0 reset pin.                     |
|        |        |        |         | UART4_RXD   | I    | MFP7  | UART4 data receiver input pin.              |
|        |        |        |         | UART1_RXD   | I    | MFP8  | UART1 data receiver input pin.              |
|        |        |        |         | I2C1_SDA    | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |        |        |         | BPWM0_CH2   | I/O  | MFP12 | BPWM0 channel 2 output/capture input.       |
|        |        |        |         | EPWM0_CH3   | I/O  | MFP13 | EPWM0 channel 3 output/capture input.       |
| 13     | 21     | 29     | 59      | PA.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | SPIM_MISO   | I/O  | MFP2  | SPIM MISO (Master In, Slave Out) pin.       |
|        |        |        |         | QSPI0_MISO0 | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |        |        |         | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|        |        |        |         | SD1_DAT1    | I/O  | MFP5  | SD/SDIO1 data line bit 1.                   |
|        |        |        |         | SC0_DAT     | I/O  | MFP6  | Smart Card 0 data pin.                      |
|        |        |        |         | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.          |
|        |        |        |         | UART1_nCTS  | I    | MFP8  | UART1 clear to Send input pin.              |
|        |        |        |         | I2C2_SCL    | I/O  | MFP9  | I2C2 clock pin.                             |
|        |        |        |         | BPWM0_CH1   | I/O  | MFP12 | BPWM0 channel 1 output/capture input.       |
|        |        |        |         | EPWM0_CH4   | I/O  | MFP13 | EPWM0 channel 4 output/capture input.       |
|        |        |        |         | DAC1_ST     | I    | MFP15 | DAC1 external trigger input.                |
| 14     | 22     | 30     | 60      | PA.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | SPIM_MOSI   | I/O  | MFP2  | SPIM MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | QSPI0_MOSI0 | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name          | Type | MFP   | Description                                                                                          |
|--------|--------|--------|---------|-------------------|------|-------|------------------------------------------------------------------------------------------------------|
|        |        |        |         | SPI0_MOSI         | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.                                                                |
|        |        |        |         | SD1_DAT0          | I/O  | MFP5  | SD/SDIO1 data line bit 0.                                                                            |
|        |        |        |         | SC0_CLK           | O    | MFP6  | Smart Card 0 clock pin.                                                                              |
|        |        |        |         | UART0_RXD         | I    | MFP7  | UART0 data receiver input pin.                                                                       |
|        |        |        |         | UART1_nRTS        | O    | MFP8  | UART1 request to Send output pin.                                                                    |
|        |        |        |         | I2C2_SDA          | I/O  | MFP9  | I2C2 data input/output pin.                                                                          |
|        |        |        |         | BPWM0_CH0         | I/O  | MFP12 | BPWM0 channel 0 output/capture input.                                                                |
|        |        |        |         | EPWM0_CH5         | I/O  | MFP13 | EPWM0 channel 5 output/capture input.                                                                |
|        |        |        |         | DAC0_ST           | I    | MFP15 | DAC0 external trigger input.                                                                         |
| 15     | 23     | 31     | 61      | V <sub>DDIO</sub> | P    | MFP0  | Power supply for PA.0~PA.5.                                                                          |
|        |        |        | 62      | PE.14             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | EBI_AD8           | I/O  | MFP2  | EBI address/data bus bit 8.                                                                          |
|        |        |        |         | UART2_TXD         | O    | MFP3  | UART2 data transmitter output pin.                                                                   |
|        |        |        |         | CAN0_TXD          | O    | MFP4  | CAN0 bus transmitter output.                                                                         |
|        |        |        |         | SD1_nCD           | I    | MFP5  | SD/SDIO1 card detect input pin                                                                       |
|        |        |        | 63      | PE.15             | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | EBI_AD9           | I/O  | MFP2  | EBI address/data bus bit 9.                                                                          |
|        |        |        |         | UART2_RXD         | I    | MFP3  | UART2 data receiver input pin.                                                                       |
|        |        |        |         | CAN0_RXD          | I    | MFP4  | CAN0 bus receiver input.                                                                             |
| 16     | 24     | 32     | 64      | nRESET            | I    | MFP0  | External reset input: active LOW, with an internal pull-up. Set this pin low reset to initial state. |
|        |        |        | 65      | PF.0              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | UART1_TXD         | O    | MFP2  | UART1 data transmitter output pin.                                                                   |
|        |        |        |         | I2C1_SCL          | I/O  | MFP3  | I2C1 clock pin.                                                                                      |
|        |        |        |         | BPWM1_CH0         | I/O  | MFP12 | BPWM1 channel 0 output/capture input.                                                                |
|        |        |        |         | ICE_DAT           | O    | MFP14 | Serial wired debugger data pin.                                                                      |
|        |        |        | 66      | PF.1              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | UART1_RXD         | I    | MFP2  | UART1 data receiver input pin.                                                                       |
|        |        |        |         | I2C1_SDA          | I/O  | MFP3  | I2C1 data input/output pin.                                                                          |
|        |        |        |         | BPWM1_CH1         | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                                                                |
|        |        |        |         | ICE_CLK           | I    | MFP14 | Serial wired debugger clock pin.                                                                     |
|        |        |        | 67      | PD.9              | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |        |        |         | EBI_AD7           | I/O  | MFP2  | EBI address/data bus bit 7.                                                                          |
|        |        |        |         | I2C2_SCL          | I/O  | MFP3  | I2C2 clock pin.                                                                                      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | UART2_nCTS   | I    | MFP4  | UART2 clear to Send input pin.              |
|        |        | 68     |         | PD.8         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD6      | I/O  | MFP2  | EBI address/data bus bit 6.                 |
|        |        |        |         | I2C2_SDA     | I/O  | MFP3  | I2C2 data input/output pin.                 |
|        |        |        |         | UART2_nRTS   | O    | MFP4  | UART2 request to Send output pin.           |
|        | 27     | 35     | 69      | PC.5         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD5      | I/O  | MFP2  | EBI address/data bus bit 5.                 |
|        |        |        |         | SPIM_D2      | I/O  | MFP3  | SPIM data 2 pin for Quad Mode I/O.          |
|        |        |        |         | QSPI0_MISO1  | I/O  | MFP4  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |        |        |         | UART2_TXD    | O    | MFP8  | UART2 data transmitter output pin.          |
|        |        |        |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |        |        |         | CAN0_TXD     | O    | MFP10 | CAN0 bus transmitter output.                |
|        |        |        |         | UART4_TXD    | O    | MFP11 | UART4 data transmitter output pin.          |
|        |        |        |         | EPWM1_CH0    | I/O  | MFP12 | EPWM1 channel 0 output/capture input.       |
|        |        |        |         | PC.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        | 28     | 36     | 70      | EBI_AD4      | I/O  | MFP2  | EBI address/data bus bit 4.                 |
|        |        |        |         | SPIM_D3      | I/O  | MFP3  | SPIM data 3 pin for Quad Mode I/O.          |
|        |        |        |         | QSPI0_MOSI1  | I/O  | MFP4  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |        |        |         | SC1_nCD      | I    | MFP5  | Smart Card 1 card detect pin.               |
|        |        |        |         | I2S0_BCLK    | O    | MFP6  | I2S0 bit clock output pin.                  |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP7  | SPI1 I2S master clock output pin            |
|        |        |        |         | UART2_RXD    | I    | MFP8  | UART2 data receiver input pin.              |
|        |        |        |         | I2C1_SDA     | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |        |        |         | CAN0_RXD     | I    | MFP10 | CAN0 bus receiver input.                    |
|        |        |        |         | UART4_RXD    | I    | MFP11 | UART4 data receiver input pin.              |
|        |        |        |         | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        | 29     | 37     | 71      | PC.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD3      | I/O  | MFP2  | EBI address/data bus bit 3.                 |
|        |        |        |         | SPIM_SS      | I/O  | MFP3  | SPIM slave select pin.                      |
|        |        |        |         | QSPI0_SS     | I/O  | MFP4  | Quad SPI0 slave select pin.                 |
|        |        |        |         | SC1_PWR      | O    | MFP5  | Smart Card 1 power pin.                     |
|        |        |        |         | I2S0_MCLK    | O    | MFP6  | I2S0 master clock output pin.               |
|        |        |        |         | SPI1_MISO    | I/O  | MFP7  | SPI1 MISO (Master In, Slave Out) pin.       |
|        |        |        |         | UART2_nRTS   | O    | MFP8  | UART2 request to Send output pin.           |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name    | Type | MFP   | Description                                 |
|--------|--------|--------|---------|-------------|------|-------|---------------------------------------------|
|        |        |        |         | I2C0_SMBAL  | O    | MFP9  | I2C0 SMBus SMBALTER pin                     |
|        |        |        |         | CAN1_TXD    | O    | MFP10 | CAN1 bus transmitter output.                |
|        |        |        |         | UART3_TXD   | O    | MFP11 | UART3 data transmitter output pin.          |
|        |        |        |         | EPWM1_CH2   | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        |        |        |         | PC.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD2     | I/O  | MFP2  | EBI address/data bus bit 2.                 |
|        |        |        |         | SPIM_CLK    | I/O  | MFP3  | SPIM serial clock pin.                      |
|        |        |        |         | QSPI0_CLK   | I/O  | MFP4  | Quad SPI0 serial clock pin.                 |
|        |        |        |         | SC1_RST     | O    | MFP5  | Smart Card 1 reset pin.                     |
|        |        |        |         | I2S0_DI     | I    | MFP6  | I2S0 data input pin.                        |
|        |        |        |         | SPI1_MOSI   | I/O  | MFP7  | SPI1 MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | UART2_nCTS  | I    | MFP8  | UART2 clear to Send input pin.              |
|        |        |        |         | I2C0_SMBSUS | O    | MFP9  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |        |        |         | CAN1_RXD    | I    | MFP10 | CAN1 bus receiver input.                    |
|        |        |        |         | UART3_RXD   | I    | MFP11 | UART3 data receiver input pin.              |
|        |        |        |         | EPWM1_CH3   | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        |        |        |         | PC.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD1     | I/O  | MFP2  | EBI address/data bus bit 1.                 |
|        |        |        |         | SPIM_MISO   | I/O  | MFP3  | SPIM MISO (Master In, Slave Out) pin.       |
|        |        |        |         | QSPI0_MISO0 | I/O  | MFP4  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |        |        |         | SC1_DAT     | I/O  | MFP5  | Smart Card 1 data pin.                      |
|        |        |        |         | I2S0_DO     | O    | MFP6  | I2S0 data output pin.                       |
|        |        |        |         | SPI1_CLK    | I/O  | MFP7  | SPI1 serial clock pin.                      |
|        |        |        |         | UART2_TXD   | O    | MFP8  | UART2 data transmitter output pin.          |
|        |        |        |         | I2C0_SCL    | I/O  | MFP9  | I2C0 clock pin.                             |
|        |        |        |         | EPWM1_CH4   | I/O  | MFP12 | EPWM1 channel 4 output/capture input.       |
|        |        |        |         | ACMP0_O     | O    | MFP14 | Analog comparator 0 output pin.             |
|        |        |        |         | PC.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD0     | I/O  | MFP2  | EBI address/data bus bit 0.                 |
|        |        |        |         | SPIM_MOSI   | I/O  | MFP3  | SPIM MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | QSPI0_MOSI0 | I/O  | MFP4  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|        |        |        |         | SC1_CLK     | O    | MFP5  | Smart Card 1 clock pin.                     |
|        |        |        |         | I2S0_LRCK   | O    | MFP6  | I2S0 left right channel clock output pin.   |
|        |        |        |         | SPI1_SS     | I/O  | MFP7  | SPI1 slave select pin.                      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        |         | UART2_RXD       | I    | MFP8  | UART2 data receiver input pin.                                                  |
|        |        |        |         | I2C0_SDA        | I/O  | MFP9  | I2C0 data input/output pin.                                                     |
|        |        |        |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |        |        |         | ACMP1_O         | O    | MFP14 | Analog comparator 1 output pin.                                                 |
|        |        |        | 75      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        | 76      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 77      | PG.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD0         | I/O  | MFP2  | EBI address/data bus bit 0.                                                     |
|        |        |        |         | SD1_DAT3        | I/O  | MFP3  | SD/SDIO1 data line bit 3.                                                       |
|        |        |        |         | SPI_M_D2        | I/O  | MFP4  | SPI_M data 2 pin for Quad Mode I/O.                                             |
|        |        |        |         | BPWM0_CH5       | I/O  | MFP12 | BPWM0 channel 5 output/capture input.                                           |
|        |        |        | 78      | PG.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD1         | I/O  | MFP2  | EBI address/data bus bit 1.                                                     |
|        |        |        |         | SD1_DAT2        | I/O  | MFP3  | SD/SDIO1 data line bit 2.                                                       |
|        |        |        |         | SPI_M_D3        | I/O  | MFP4  | SPI_M data 3 pin for Quad Mode I/O.                                             |
|        |        |        |         | BPWM0_CH4       | I/O  | MFP12 | BPWM0 channel 4 output/capture input.                                           |
|        |        |        | 79      | PG.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD2         | I/O  | MFP2  | EBI address/data bus bit 2.                                                     |
|        |        |        |         | SD1_DAT1        | I/O  | MFP3  | SD/SDIO1 data line bit 1.                                                       |
|        |        |        |         | SPI_M_SS        | I/O  | MFP4  | SPI_M slave select pin.                                                         |
|        |        |        |         | BPWM0_CH3       | I/O  | MFP12 | BPWM0 channel 3 output/capture input.                                           |
|        |        |        | 80      | PG.12           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD3         | I/O  | MFP2  | EBI address/data bus bit 3.                                                     |
|        |        |        |         | SD1_DAT0        | I/O  | MFP3  | SD/SDIO1 data line bit 0.                                                       |
|        |        |        |         | SPI_M_CLK       | I/O  | MFP4  | SPI_M serial clock pin.                                                         |
|        |        |        |         | BPWM0_CH2       | I/O  | MFP12 | BPWM0 channel 2 output/capture input.                                           |
|        |        |        | 81      | PG.13           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD4         | I/O  | MFP2  | EBI address/data bus bit 4.                                                     |
|        |        |        |         | SD1_CMD         | I/O  | MFP3  | SD/SDIO1 command/response pin                                                   |
|        |        |        |         | SPI_M_MISO      | I/O  | MFP4  | SPI_M MISO (Master In, Slave Out) pin.                                          |
|        |        |        |         | BPWM0_CH1       | I/O  | MFP12 | BPWM0 channel 1 output/capture input.                                           |
|        |        |        | 82      | PG.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD5         | I/O  | MFP2  | EBI address/data bus bit 5.                                                     |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------|
|        |        |        |         | SD1_CLK      | O    | MFP3  | SD/SDIO1 clock output pin             |
|        |        |        |         | SPI_MOSI     | I/O  | MFP4  | SPI MISO (Master Out, Slave In) pin.  |
|        |        |        |         | BPWM0_CH0    | I/O  | MFP12 | BPWM0 channel 0 output/capture input. |
|        |        |        | 83      | PG.15        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | SD1_nCD      | I    | MFP3  | SD/SDIO1 card detect input pin        |
|        |        |        |         | CLKO         | O    | MFP14 | Clock Out                             |
|        |        |        |         | EADC0_ST     | I    | MFP15 | EADC0 external trigger input.         |
|        |        |        | 84      | PD.13        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_AD10     | I/O  | MFP2  | EBI address/data bus bit 10.          |
|        |        |        |         | SD0_nCD      | I    | MFP3  | SD/SDIO0 card detect input pin        |
|        |        |        |         | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin      |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin      |
|        |        |        |         | SC2_nCD      | I    | MFP7  | Smart Card 2 card detect pin.         |
|        |        |        | 85      | PA.12        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | I2S0_BCLK    | O    | MFP2  | I2S0 bit clock output pin.            |
|        |        |        |         | UART4_TXD    | O    | MFP3  | UART4 data transmitter output pin.    |
|        |        |        |         | I2C1_SCL     | I/O  | MFP4  | I2C1 clock pin.                       |
|        |        |        |         | SPI2_SS      | I/O  | MFP5  | SPI2 slave select pin.                |
|        |        |        |         | CAN0_TXD     | O    | MFP6  | CAN0 bus transmitter output.          |
|        |        |        |         | SC2_PWR      | O    | MFP7  | Smart Card 2 power pin.               |
|        |        |        |         | BPWM1_CH2    | I/O  | MFP11 | BPWM1 channel 2 output/capture input. |
|        |        |        |         | QEI1_INDEX   | I    | MFP12 | Quadrature encoder 1 index input      |
|        |        |        |         | USB_VBUS     | P    | MFP14 | Power supply from USB host or HUB.    |
|        |        |        | 86      | PA.13        | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | I2S0_MCLK    | O    | MFP2  | I2S0 master clock output pin.         |
|        |        |        |         | UART4_RXD    | I    | MFP3  | UART4 data receiver input pin.        |
|        |        |        |         | I2C1_SDA     | I/O  | MFP4  | I2C1 data input/output pin.           |
|        |        |        |         | SPI2_CLK     | I/O  | MFP5  | SPI2 serial clock pin.                |
|        |        |        |         | CAN0_RXD     | I    | MFP6  | CAN0 bus receiver input.              |
|        |        |        |         | SC2_RST      | O    | MFP7  | Smart Card 2 reset pin.               |
|        |        |        |         | BPWM1_CH3    | I/O  | MFP11 | BPWM1 channel 3 output/capture input. |
|        |        |        |         | QEI1_A       | I    | MFP12 | Quadrature encoder 1 phase A input    |
|        |        |        |         | USB_D-       | A    | MFP14 | USB differential signal D-.           |
| 23     | 35     |        | 87      | PA.14        | I/O  | MFP0  | General purpose digital I/O pin.      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                                                              |
|--------|--------|--------|---------|-----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------|
|        |        |        |         | I2S0_DI         | I    | MFP2  | I2S0 data input pin.                                                                                                     |
|        |        |        |         | UART0_TXD       | O    | MFP3  | UART0 data transmitter output pin.                                                                                       |
|        |        |        |         | SPI2_MISO       | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.                                                                                    |
|        |        |        |         | I2C2_SCL        | I/O  | MFP6  | I2C2 clock pin.                                                                                                          |
|        |        |        |         | SC2_DAT         | I/O  | MFP7  | Smart Card 2 data pin.                                                                                                   |
|        |        |        |         | BPWM1_CH4       | I/O  | MFP11 | BPWM1 channel 4 output/capture input.                                                                                    |
|        |        |        |         | QEI1_B          | I    | MFP12 | Quadrature encoder 1 phase B input                                                                                       |
|        |        |        |         | USB_D+          | A    | MFP14 | USB differential signal D+.                                                                                              |
| 24     | 36     | 88     |         | PA.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |        |        |         | I2S0_DO         | O    | MFP2  | I2S0 data output pin.                                                                                                    |
|        |        |        |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.                                                                                           |
|        |        |        |         | SPI2_MOSI       | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.                                                                                    |
|        |        |        |         | I2C2_SDA        | I/O  | MFP6  | I2C2 data input/output pin.                                                                                              |
|        |        |        |         | SC2_CLK         | O    | MFP7  | Smart Card 2 clock pin.                                                                                                  |
|        |        |        |         | BPWM1_CH5       | I/O  | MFP11 | BPWM1 channel 5 output/capture input.                                                                                    |
|        |        |        |         | EPWM0_SYNC_IN   | I    | MFP12 | EPWM0 counter synchronous trigger input pin.                                                                             |
|        |        |        |         | USB_OTG_ID      | I    | MFP14 | USB_ identification.                                                                                                     |
|        | 41     | 89     |         | HSUSB_VRES      | A    | MFP0  | HSUSB module reference resister                                                                                          |
|        | 42     | 90     |         | HSUSB_VDD33     | P    | MFP0  | Power supply for HSUSB VDD33                                                                                             |
|        | 43     | 91     |         | HSUSB_VBUS      | P    | MFP0  | HSUSB Power supply from USB host or HUB.                                                                                 |
|        | 44     | 92     |         | HSUSB_D-        | A    | MFP0  | HSUSB differential signal D-.                                                                                            |
|        | 45     | 93     |         | HSUSB_VSS       | P    | MFP0  | Ground pin for HSUSB.                                                                                                    |
|        | 46     | 94     |         | HSUSB_D+        | A    | MFP0  | HSUSB differential signal D+.                                                                                            |
|        | 47     | 95     |         | HSUSB_VDD12_CAP | A    | MFP0  | HSUSB Internal power regulator output 1.2V decoupling pin.<br>Note: This pin needs to be connected with a 1uF capacitor. |
|        | 48     | 96     |         | HSUSB_ID        | I    | MFP0  | HSUSB identification.                                                                                                    |
|        |        | 97     |         | PE.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |        |        |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                                                            |
|        |        |        |         | SPIM_D2         | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.                                                                                       |
|        |        |        |         | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.                                                                                       |
|        |        |        |         | CAN1_TXD        | O    | MFP9  | CAN1 bus transmitter output.                                                                                             |
|        |        |        |         | QEI1_INDEX      | I    | MFP11 | Quadrature encoder 1 index input                                                                                         |
|        |        |        |         | EPWM0_CH0       | I/O  | MFP12 | EPWM0 channel 0 output/capture input.                                                                                    |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                           |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------|
|        |        |        |         | BPWM0_CH5    | I/O  | MFP13 | BPWM0 channel 5 output/capture input. |
|        |        |        | 98      | PE.6         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | SD0_CLK      | O    | MFP3  | SD/SDIO0 clock output pin             |
|        |        |        |         | SPIM_D3      | I/O  | MFP4  | SPIM data 3 pin for Quad Mode I/O.    |
|        |        |        |         | SPI3_I2SMCLK | I/O  | MFP5  | SPI3 I2S master clock output pin      |
|        |        |        |         | SC0_nCD      | I    | MFP6  | Smart Card 0 card detect pin.         |
|        |        |        |         | USCI0_CTL0   | I/O  | MFP7  | USCI0 control 0 pin.                  |
|        |        |        |         | UART5_RXD    | I    | MFP8  | UART5 data receiver input pin.        |
|        |        |        |         | CAN1_RXD     | I    | MFP9  | CAN1 bus receiver input.              |
|        |        |        |         | QEI1_A       | I    | MFP11 | Quadrature encoder 1 phase A input    |
|        |        |        |         | EPWM0_CH1    | I/O  | MFP12 | EPWM0 channel 1 output/capture input. |
|        |        |        |         | BPWM0_CH4    | I/O  | MFP13 | BPWM0 channel 4 output/capture input. |
|        |        |        | 99      | PE.5         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_nRD      | O    | MFP2  | EBI read enable output pin.           |
|        |        |        |         | SD0_DAT3     | I/O  | MFP3  | SD/SDIO0 data line bit 3.             |
|        |        |        |         | SPIM_SS      | I/O  | MFP4  | SPIM slave select pin.                |
|        |        |        |         | SPI3_SS      | I/O  | MFP5  | SPI3 slave select pin.                |
|        |        |        |         | SC0_PWR      | O    | MFP6  | Smart Card 0 power pin.               |
|        |        |        |         | USCI0_CTL1   | I/O  | MFP7  | USCI0 control 1 pin.                  |
|        |        |        |         | QEI1_B       | I    | MFP11 | Quadrature encoder 1 phase B input    |
|        |        |        |         | EPWM0_CH2    | I/O  | MFP12 | EPWM0 channel 2 output/capture input. |
|        |        |        |         | BPWM0_CH3    | I/O  | MFP13 | BPWM0 channel 3 output/capture input. |
|        |        |        | 100     | PE.4         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_nWR      | O    | MFP2  | EBI write enable output pin.          |
|        |        |        |         | SD0_DAT2     | I/O  | MFP3  | SD/SDIO0 data line bit 2.             |
|        |        |        |         | SPIM_CLK     | I/O  | MFP4  | SPIM serial clock pin.                |
|        |        |        |         | SPI3_CLK     | I/O  | MFP5  | SPI3 serial clock pin.                |
|        |        |        |         | SC0_RST      | O    | MFP6  | Smart Card 0 reset pin.               |
|        |        |        |         | USCI0_DAT1   | I/O  | MFP7  | USCI0 data 1 pin.                     |
|        |        |        |         | QEIO_INDEX   | I    | MFP11 | Quadrature encoder 0 index input      |
|        |        |        |         | EPWM0_CH3    | I/O  | MFP12 | EPWM0 channel 3 output/capture input. |
|        |        |        |         | BPWM0_CH2    | I/O  | MFP13 | BPWM0 channel 2 output/capture input. |
|        |        |        | 101     | PE.3         | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |        |        |         | EBI_MCLK     | O    | MFP2  | EBI external clock output pin.        |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        |         | SD0_DAT1        | I/O  | MFP3  | SD/SDIO0 data line bit 1.                                                       |
|        |        |        |         | SPIIM_MISO      | I/O  | MFP4  | SPIIM MISO (Master In, Slave Out) pin.                                          |
|        |        |        |         | SPI3_MISO       | I/O  | MFP5  | SPI3 MISO (Master In, Slave Out) pin.                                           |
|        |        |        |         | SC0_DAT         | I/O  | MFP6  | Smart Card 0 data pin.                                                          |
|        |        |        |         | USCI0_DAT0      | I/O  | MFP7  | USCI0 data 0 pin.                                                               |
|        |        |        |         | QEI0_A          | I    | MFP11 | Quadrature encoder 0 phase A input                                              |
|        |        |        |         | EPWM0_CH4       | I/O  | MFP12 | EPWM0 channel 4 output/capture input.                                           |
|        |        |        |         | BPWM0_CH1       | I/O  | MFP13 | BPWM0 channel 1 output/capture input.                                           |
|        |        |        | 102     | PE.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_ALE         | O    | MFP2  | EBI address latch enable output pin.                                            |
|        |        |        |         | SD0_DAT0        | I/O  | MFP3  | SD/SDIO0 data line bit 0.                                                       |
|        |        |        |         | SPIIM_MOSI      | I/O  | MFP4  | SPIIM MOSI (Master Out, Slave In) pin.                                          |
|        |        |        |         | SPI3_MOSI       | I/O  | MFP5  | SPI3 MOSI (Master Out, Slave In) pin.                                           |
|        |        |        |         | SC0_CLK         | O    | MFP6  | Smart Card 0 clock pin.                                                         |
|        |        |        |         | USCI0_CLK       | I/O  | MFP7  | USCI0 clock pin.                                                                |
|        |        |        |         | QEI0_B          | I    | MFP11 | Quadrature encoder 0 phase B input                                              |
|        |        |        |         | EPWM0_CH5       | I/O  | MFP12 | EPWM0 channel 5 output/capture input.                                           |
|        |        |        |         | BPWM0_CH0       | I/O  | MFP13 | BPWM0 channel 0 output/capture input.                                           |
|        |        |        | 103     | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |        |        | 104     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 105     | PE.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD10        | I/O  | MFP2  | EBI address/data bus bit 10.                                                    |
|        |        |        |         | QSPI0_MISO0     | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin.                                     |
|        |        |        |         | SC2_DAT         | I/O  | MFP4  | Smart Card 2 data pin.                                                          |
|        |        |        |         | I2S0_BCLK       | O    | MFP5  | I2S0 bit clock output pin.                                                      |
|        |        |        |         | SPI1_MISO       | I/O  | MFP6  | SPI1 MISO (Master In, Slave Out) pin.                                           |
|        |        |        |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |        |        |         | I2C1_SCL        | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |        |        |         | UART4_nCTS      | I    | MFP9  | UART4 clear to Send input pin.                                                  |
|        |        |        | 106     | PE.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |        |        |         | QSPI0_MOSI0     | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.                                     |
|        |        |        |         | SC2_CLK         | O    | MFP4  | Smart Card 2 clock pin.                                                         |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|--------|--------|---------|--------------|------|-------|---------------------------------------------|
|        |        |        |         | I2S0_MCLK    | O    | MFP5  | I2S0 master clock output pin.               |
|        |        |        |         | SPI1_MOSI    | I/O  | MFP6  | SPI1 MOSI (Master Out, Slave In) pin.       |
|        |        |        |         | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.              |
|        |        |        |         | I2C1_SDA     | I/O  | MFP8  | I2C1 data input/output pin.                 |
|        |        |        |         | UART4_nRTS   | O    | MFP9  | UART4 request to Send output pin.           |
|        |        |        | 107     | PH.8         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD12     | I/O  | MFP2  | EBI address/data bus bit 12.                |
|        |        |        |         | QSPI0_CLK    | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |        |        |         | SC2_PWR      | O    | MFP4  | Smart Card 2 power pin.                     |
|        |        |        |         | I2S0_DI      | I    | MFP5  | I2S0 data input pin.                        |
|        |        |        |         | SPI1_CLK     | I/O  | MFP6  | SPI1 serial clock pin.                      |
|        |        |        |         | UART3_nRTS   | O    | MFP7  | UART3 request to Send output pin.           |
|        |        |        |         | I2C1_SMBAL   | O    | MFP8  | I2C1 SMBus SMBALTER pin                     |
|        |        |        |         | I2C2_SCL     | I/O  | MFP9  | I2C2 clock pin.                             |
|        |        |        |         | UART1_TXD    | O    | MFP10 | UART1 data transmitter output pin.          |
|        |        |        | 108     | PH.9         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD13     | I/O  | MFP2  | EBI address/data bus bit 13.                |
|        |        |        |         | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                 |
|        |        |        |         | SC2_RST      | O    | MFP4  | Smart Card 2 reset pin.                     |
|        |        |        |         | I2S0_DO      | O    | MFP5  | I2S0 data output pin.                       |
|        |        |        |         | SPI1_SS      | I/O  | MFP6  | SPI1 slave select pin.                      |
|        |        |        |         | UART3_nCTS   | I    | MFP7  | UART3 clear to Send input pin.              |
|        |        |        |         | I2C1_SMBSUS  | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |        |        |         | I2C2_SDA     | I/O  | MFP9  | I2C2 data input/output pin.                 |
|        |        |        |         | UART1_RXD    | I    | MFP10 | UART1 data receiver input pin.              |
|        |        |        | 109     | PH.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |        |        |         | EBI_AD14     | I/O  | MFP2  | EBI address/data bus bit 14.                |
|        |        |        |         | QSPI0_MISO1  | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |        |        |         | SC2_nCD      | I    | MFP4  | Smart Card 2 card detect pin.               |
|        |        |        |         | I2S0_LRCK    | O    | MFP5  | I2S0 left right channel clock output pin.   |
|        |        |        |         | SPI1_I2SMCLK | I/O  | MFP6  | SPI1 I2S master clock output pin            |
|        |        |        |         | UART4_TXD    | O    | MFP7  | UART4 data transmitter output pin.          |
|        |        |        |         | UART0_TXD    | O    | MFP8  | UART0 data transmitter output pin.          |
|        |        |        | 110     | PH.11        | I/O  | MFP0  | General purpose digital I/O pin.            |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|--------|--------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |        |        |         | EBI_AD15        | I/O  | MFP2  | EBI address/data bus bit 15.                                                    |
|        |        |        |         | QSPI0_MOSI1     | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin.                                     |
|        |        |        |         | UART4_RXD       | I    | MFP7  | UART4 data receiver input pin.                                                  |
|        |        |        |         | UART0_RXD       | I    | MFP8  | UART0 data receiver input pin.                                                  |
|        |        |        |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |        |        | 111     | PD.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_nCS0        | O    | MFP2  | EBI chip select 0 output pin.                                                   |
|        |        |        |         | SPI3_I2SMCLK    | I/O  | MFP3  | SPI3 I2S master clock output pin                                                |
|        |        |        |         | SC1_nCD         | I    | MFP4  | Smart Card 1 card detect pin.                                                   |
|        |        |        |         | EPWM0_CH4       | I/O  | MFP11 | EPWM0 channel 4 output/capture input.                                           |
| 25     | 37     | 49     | 112     | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 26     | 38     | 50     | 113     | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |
| 27     | 39     | 51     | 114     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |        |        | 115     | PC.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |        |        |         | SC1_nCD         | I    | MFP3  | Smart Card 1 card detect pin.                                                   |
|        |        |        |         | SPI0_I2SMCLK    | I/O  | MFP4  | SPI0 I2S master clock output pin                                                |
|        |        |        |         | USCI0_CTL0      | I/O  | MFP5  | USCI0 control 0 pin.                                                            |
|        |        |        |         | QSPI0_CLK       | I/O  | MFP6  | Quad SPI0 serial clock pin.                                                     |
|        |        |        |         | EPWM0_SYNC_IN   | I    | MFP11 | EPWM0 counter synchronous trigger input pin.                                    |
|        |        |        |         | TM1             | I/O  | MFP13 | Timer1 event counter input/toggle output pin.                                   |
|        |        |        |         | USB_VBUS_ST     | I    | MFP14 | USB external VBUS regulator status pin.                                         |
|        |        |        |         | HSUSB_VBUS_ST   | I    | MFP15 | HSUSB external VBUS regulator status pin.                                       |
|        |        |        | 116     | PB.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |        |        |         | EADC0_CH15      | A    | MFP1  | EADC0 channel 15 analog input.                                                  |
|        |        |        |         | EBI_AD12        | I/O  | MFP2  | EBI address/data bus bit 12.                                                    |
|        |        |        |         | SC1_PWR         | O    | MFP3  | Smart Card 1 power pin.                                                         |
|        |        |        |         | SPI0_SS         | I/O  | MFP4  | SPI0 slave select pin.                                                          |
|        |        |        |         | USCI0_CTL1      | I/O  | MFP5  | USCI0 control 1 pin.                                                            |
|        |        |        |         | UART0_nCTS      | I    | MFP6  | UART0 clear to Send input pin.                                                  |
|        |        |        |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |        |        |         | I2C2_SMBAL      | O    | MFP8  | I2C2 SMBus SMBALTER pin                                                         |
|        |        |        |         | EPWM1_CH0       | I/O  | MFP11 | EPWM1 channel 0 output/capture input.                                           |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name      | Type | MFP   | Description                                      |
|--------|--------|--------|---------|---------------|------|-------|--------------------------------------------------|
|        |        |        |         | TM0_EXT       | I/O  | MFP13 | Timer0 external capture input/toggle output pin. |
|        |        |        |         | USB_VBUS_EN   | O    | MFP14 | USB external VBUS regulator enable pin.          |
|        |        |        |         | HSUSB_VBUS_EN | O    | MFP15 | HSUSB external VBUS regulator enable pin.        |
| 29     | 42     | 54     | 117     | PB.14         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | EADC0_CH14    | A    | MFP1  | EADC0 channel 14 analog input.                   |
|        |        |        |         | EBI_AD13      | I/O  | MFP2  | EBI address/data bus bit 13.                     |
|        |        |        |         | SC1_RST       | O    | MFP3  | Smart Card 1 reset pin.                          |
|        |        |        |         | SPI0_CLK      | I/O  | MFP4  | SPI0 serial clock pin.                           |
|        |        |        |         | USCI0_DAT1    | I/O  | MFP5  | USCI0 data 1 pin.                                |
|        |        |        |         | UART0_nRTS    | O    | MFP6  | UART0 request to Send output pin.                |
|        |        |        |         | UART3_RXD     | I    | MFP7  | UART3 data receiver input pin.                   |
|        |        |        |         | I2C2_SMBSUS   | O    | MFP8  | I2C2 SMBus SMBSUS pin (PMBus CONTROL pin)        |
|        |        |        |         | EPWM1_CH1     | I/O  | MFP11 | EPWM1 channel 1 output/capture input.            |
|        |        |        |         | TM1_EXT       | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |        |        |         | CLKO          | O    | MFP14 | Clock Out                                        |
| 30     | 43     | 55     | 118     | PB.13         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | EADC0_CH13    | A    | MFP1  | EADC0 channel 13 analog input.                   |
|        |        |        |         | DAC1_OUT      | A    | MFP1  | DAC1 channel analog output.                      |
|        |        |        |         | ACMP0_P3      | A    | MFP1  | Analog comparator 0 positive input 3 pin.        |
|        |        |        |         | ACMP1_P3      | A    | MFP1  | Analog comparator 1 positive input 3 pin.        |
|        |        |        |         | EBI_AD14      | I/O  | MFP2  | EBI address/data bus bit 14.                     |
|        |        |        |         | SC1_DAT       | I/O  | MFP3  | Smart Card 1 data pin.                           |
|        |        |        |         | SPI0_MISO     | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.            |
|        |        |        |         | USCI0_DAT0    | I/O  | MFP5  | USCI0 data 0 pin.                                |
|        |        |        |         | UART0_TXD     | O    | MFP6  | UART0 data transmitter output pin.               |
|        |        |        |         | UART3_nRTS    | O    | MFP7  | UART3 request to Send output pin.                |
|        |        |        |         | I2C2_SCL      | I/O  | MFP8  | I2C2 clock pin.                                  |
|        |        |        |         | EPWM1_CH2     | I/O  | MFP11 | EPWM1 channel 2 output/capture input.            |
|        |        |        |         | TM2_EXT       | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
| 31     | 44     | 56     | 119     | PB.12         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |        |        |         | EADC0_CH12    | A    | MFP1  | EADC0 channel 12 analog input.                   |
|        |        |        |         | DAC0_OUT      | A    | MFP1  | DAC0 channel analog output.                      |
|        |        |        |         | ACMP0_P2      | A    | MFP1  | Analog comparator 0 positive input 2 pin.        |
|        |        |        |         | ACMP1_P2      | A    | MFP1  | Analog comparator 1 positive input 2 pin.        |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name         | Type | MFP   | Description                                                                                |
|--------|--------|--------|---------|------------------|------|-------|--------------------------------------------------------------------------------------------|
|        |        |        |         | EBI_AD15         | I/O  | MFP2  | EBI address/data bus bit 15.                                                               |
|        |        |        |         | SC1_CLK          | O    | MFP3  | Smart Card 1 clock pin.                                                                    |
|        |        |        |         | SPI0_MOSI        | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.                                                      |
|        |        |        |         | USCI0_CLK        | I/O  | MFP5  | USCI0 clock pin.                                                                           |
|        |        |        |         | UART0_RXD        | I    | MFP6  | UART0 data receiver input pin.                                                             |
|        |        |        |         | UART3_nCTS       | I    | MFP7  | UART3 clear to Send input pin.                                                             |
|        |        |        |         | I2C2_SDA         | I/O  | MFP8  | I2C2 data input/output pin.                                                                |
|        |        |        |         | SD0_nCD          | I    | MFP9  | SD/SDIO0 card detect input pin                                                             |
|        |        |        |         | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                                                      |
|        |        |        |         | TM3_EXT          | I/O  | MFP13 | Timer3 external capture input/toggle output pin.                                           |
| 32     | 45     | 57     | 120     | AV <sub>DD</sub> | P    | MFP0  | Power supply for internal analog circuit.                                                  |
|        |        | 58     | 121     | V <sub>REF</sub> | A    | MFP0  | ADC reference voltage input.<br>Note: This pin needs to be connected with a 1uF capacitor. |
|        | 46     | 59     | 122     | AV <sub>ss</sub> | P    | MFP0  | Ground pin for analog circuit.                                                             |
|        |        |        |         | PB.11            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        |         | EADC0_CH11       | A    | MFP1  | EADC0 channel 11 analog input.                                                             |
|        |        |        |         | EBI_ADR16        | O    | MFP2  | EBI address bus bit 16.                                                                    |
|        |        |        |         | UART0_nCTS       | I    | MFP5  | UART0 clear to Send input pin.                                                             |
|        |        |        |         | UART4_TXD        | O    | MFP6  | UART4 data transmitter output pin.                                                         |
|        |        |        |         | I2C1_SCL         | I/O  | MFP7  | I2C1 clock pin.                                                                            |
|        |        |        |         | CAN0_TXD         | O    | MFP8  | CAN0 bus transmitter output.                                                               |
|        |        |        |         | SPI0_I2SMCLK     | I/O  | MFP9  | SPI0 I2S master clock output pin                                                           |
|        |        |        |         | BPWM1_CH0        | I/O  | MFP10 | BPWM1 channel 0 output/capture input.                                                      |
|        |        |        |         | SPI3_CLK         | I/O  | MFP11 | SPI3 serial clock pin.                                                                     |
|        |        |        |         | HSUSB_VBUS_ST    | I    | MFP14 | HSUSB external VBUS regulator status pin.                                                  |
|        |        |        |         | PB.10            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |        |        |         | EADC0_CH10       | A    | MFP1  | EADC0 channel 10 analog input.                                                             |
|        |        |        |         | EBI_ADR17        | O    | MFP2  | EBI address bus bit 17.                                                                    |
|        |        |        |         | USCI1_CTL0       | I/O  | MFP4  | USCI1 control 0 pin.                                                                       |
|        |        |        |         | UART0_nRTS       | O    | MFP5  | UART0 request to Send output pin.                                                          |
|        |        |        |         | UART4_RXD        | I    | MFP6  | UART4 data receiver input pin.                                                             |
|        |        |        |         | I2C1_SDA         | I/O  | MFP7  | I2C1 data input/output pin.                                                                |
|        |        |        |         | CAN0_RXD         | I    | MFP8  | CAN0 bus receiver input.                                                                   |
|        |        |        |         | BPWM1_CH1        | I/O  | MFP10 | BPWM1 channel 1 output/capture input.                                                      |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin | Pin Name      | Type         | MFP   | Description                               |                                       |
|--------|--------|--------|---------|---------------|--------------|-------|-------------------------------------------|---------------------------------------|
|        |        |        |         | SPI3_SS       | I/O          | MFP11 | SPI3 slave select pin.                    |                                       |
|        |        |        |         | HSUSB_VBUS_EN | O            | MFP14 | HSUSB external VBUS regulator enable pin. |                                       |
|        |        | 62     | 125     | PB.9          | I/O          | MFP0  | General purpose digital I/O pin.          |                                       |
|        |        |        |         | EADC0_CH9     | A            | MFP1  | EADC0 channel 9 analog input.             |                                       |
|        |        |        |         | EBI_ADR18     | O            | MFP2  | EBI address bus bit 18.                   |                                       |
|        |        |        |         | USCI1_CTL1    | I/O          | MFP4  | USCI1 control 1 pin.                      |                                       |
|        |        |        |         | UART0_TXD     | O            | MFP5  | UART0 data transmitter output pin.        |                                       |
|        |        |        |         | UART1_nCTS    | I            | MFP6  | UART1 clear to Send input pin.            |                                       |
|        |        |        |         | I2C1_SMBAL    | O            | MFP7  | I2C1 SMBus SMBALTER pin                   |                                       |
|        |        |        |         | BPWM1_CH2     | I/O          | MFP10 | BPWM1 channel 2 output/capture input.     |                                       |
|        |        |        |         | SPI3_MISO     | I/O          | MFP11 | SPI3 MISO (Master In, Slave Out) pin.     |                                       |
|        |        |        |         | INT7          | I            | MFP13 | External interrupt 7 input pin.           |                                       |
|        |        | 63     | 126     | PB.8          | I/O          | MFP0  | General purpose digital I/O pin.          |                                       |
|        |        |        |         | EADC0_CH8     | A            | MFP1  | EADC0 channel 8 analog input.             |                                       |
|        |        |        |         | EBI_ADR19     | O            | MFP2  | EBI address bus bit 19.                   |                                       |
|        |        |        |         | USCI1_CLK     | I/O          | MFP4  | USCI1 clock pin.                          |                                       |
|        |        |        |         | UART0_RXD     | I            | MFP5  | UART0 data receiver input pin.            |                                       |
|        |        |        |         | UART1_nRTS    | O            | MFP6  | UART1 request to Send output pin.         |                                       |
|        |        |        |         | I2C1_SMBSUS   | O            | MFP7  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |                                       |
|        |        |        |         | BPWM1_CH3     | I/O          | MFP10 | BPWM1 channel 3 output/capture input.     |                                       |
|        |        |        |         | SPI3_MOSI     | I/O          | MFP11 | SPI3 MOSI (Master Out, Slave In) pin.     |                                       |
|        |        |        |         | INT6          | I            | MFP13 | External interrupt 6 input pin.           |                                       |
|        |        | 47     | 64      | 127           | PB.7         | I/O   | MFP0                                      | General purpose digital I/O pin.      |
|        |        |        |         |               | EADC0_CH7    | A     | MFP1                                      | EADC0 channel 7 analog input.         |
|        |        |        |         |               | EBI_nWRL     | O     | MFP2                                      | EBI low byte write enable output pin. |
|        |        |        |         |               | USCI1_DAT0   | I/O   | MFP4                                      | USCI1 data 0 pin.                     |
|        |        |        |         |               | CAN1_TXD     | O     | MFP5                                      | CAN1 bus transmitter output.          |
|        |        |        |         |               | UART1_TXD    | O     | MFP6                                      | UART1 data transmitter output pin.    |
|        |        |        |         |               | SD1_CMD      | I/O   | MFP7                                      | SD/SDIO1 command/response pin         |
|        |        |        |         |               | EBI_nCS0     | O     | MFP8                                      | EBI chip select 0 output pin.         |
|        |        |        |         |               | BPWM1_CH4    | I/O   | MFP10                                     | BPWM1 channel 4 output/capture input. |
|        |        |        |         |               | EPWM1_BRAKE0 | I     | MFP11                                     | EPWM1 Brake 0 input pin.              |
|        |        |        |         |               | EPWM1_CH4    | I/O   | MFP12                                     | EPWM1 channel 4 output/capture input. |
|        |        |        |         |               | INT5         | I     | MFP13                                     | External interrupt 5 input pin.       |

| 32 Pin | 48 Pin | 64 Pin | 128 Pin      | Pin Name    | Type  | MFP   | Description                             |
|--------|--------|--------|--------------|-------------|-------|-------|-----------------------------------------|
|        |        |        |              | USB_VBUS_ST | I     | MFP14 | USB external VBUS regulator status pin. |
|        |        |        |              | ACMP0_O     | O     | MFP15 | Analog comparator 0 output pin.         |
| 48     | 1      | 128    | PB.6         | I/O         | MFP0  |       | General purpose digital I/O pin.        |
|        |        |        | EADC0_CH6    | A           | MFP1  |       | EADC0 channel 6 analog input.           |
|        |        |        | EBI_nWRH     | O           | MFP2  |       | EBI high byte write enable output pin   |
|        |        |        | USCI1_DAT1   | I/O         | MFP4  |       | USCI1 data 1 pin.                       |
|        |        |        | CAN1_RXD     | I           | MFP5  |       | CAN1 bus receiver input.                |
|        |        |        | UART1_RXD    | I           | MFP6  |       | UART1 data receiver input pin.          |
|        |        |        | SD1_CLK      | O           | MFP7  |       | SD/SDIO1 clock output pin               |
|        |        |        | EBI_nCS1     | O           | MFP8  |       | EBI chip select 1 output pin.           |
|        |        |        | BPWM1_CH5    | I/O         | MFP10 |       | BPWM1 channel 5 output/capture input.   |
|        |        |        | EPWM1_BRAKE1 | I           | MFP11 |       | EPWM1 Brake 1 input pin.                |
|        |        |        | EPWM1_CH5    | I/O         | MFP12 |       | EPWM1 channel 5 output/capture input.   |
|        |        |        | INT4         | I           | MFP13 |       | External interrupt 4 input pin.         |
|        |        |        | USB_VBUS_EN  | O           | MFP14 |       | USB external VBUS regulator enable pin. |
|        |        |        | ACMP1_O      | O           | MFP15 |       | Analog comparator 1 output pin.         |

## 4.2.6 M487 Series Pin Description

| 64 Pin | 128 Pin | 144 Pin | Pin Name         | Type | MFP   | Description                                   |
|--------|---------|---------|------------------|------|-------|-----------------------------------------------|
| 2      | 1       | 1       | PB.5             | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EADC0_CH5        | A    | MFP1  | EADC0 channel 5 analog input.                 |
|        |         |         | ACMP1_N          | A    | MFP1  | Analog comparator 1 negative input pin.       |
|        |         |         | EBI_ADR0         | O    | MFP2  | EBI address bus bit 0.                        |
|        |         |         | SD0_DAT3         | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|        |         |         | EMAC_RMII_REFCLK | I    | MFP4  | EMAC RMII reference clock input pin.          |
|        |         |         | SPI1_MISO        | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.         |
|        |         |         | I2C0_SCL         | I/O  | MFP6  | I2C0 clock pin.                               |
|        |         |         | UART5_TXD        | O    | MFP7  | UART5 data transmitter output pin.            |
|        |         |         | USCI1_CTL0       | I/O  | MFP8  | USCI1 control 0 pin.                          |
|        |         |         | SC0_CLK          | O    | MFP9  | Smart Card 0 clock pin.                       |
|        |         |         | I2S0_BCLK        | O    | MFP10 | I2S0 bit clock output pin.                    |
|        |         |         | EPWM0_CH0        | I/O  | MFP11 | EPWM0 channel 0 output/capture input.         |
|        |         |         | TM0              | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|        |         |         | INT0             | I    | MFP15 | External interrupt 0 input pin.               |
| 3      | 2       | 2       | PB.4             | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EADC0_CH4        | A    | MFP1  | EADC0 channel 4 analog input.                 |
|        |         |         | ACMP1_P1         | A    | MFP1  | Analog comparator 1 positive input 1 pin.     |
|        |         |         | EBI_ADR1         | O    | MFP2  | EBI address bus bit 1.                        |
|        |         |         | SD0_DAT2         | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|        |         |         | EMAC_RMII_RXD0   | I    | MFP4  | EMAC RMII Receive Data bus bit 0.             |
|        |         |         | SPI1_MOSI        | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.         |
|        |         |         | I2C0_SDA         | I/O  | MFP6  | I2C0 data input/output pin.                   |
|        |         |         | UART5_RXD        | I    | MFP7  | UART5 data receiver input pin.                |
|        |         |         | USCI1_CTL1       | I/O  | MFP8  | USCI1 control 1 pin.                          |
|        |         |         | SC0_DAT          | I/O  | MFP9  | Smart Card 0 data pin.                        |
|        |         |         | I2S0_MCLK        | O    | MFP10 | I2S0 master clock output pin.                 |
|        |         |         | EPWM0_CH1        | I/O  | MFP11 | EPWM0 channel 1 output/capture input.         |
|        |         |         | TM1              | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
|        |         |         | INT1             | I    | MFP15 | External interrupt 1 input pin.               |
| 4      | 3       | 3       | PB.3             | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EADC0_CH3        | A    | MFP1  | EADC0 channel 3 analog input.                 |
|        |         |         | ACMP0_N          | A    | MFP1  | Analog comparator 0 negative input pin.       |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                     |
|--------|---------|---------|-----------------|------|-------|-------------------------------------------------|
|        |         |         | EBI_ADR2        | O    | MFP2  | EBI address bus bit 2.                          |
|        |         |         | SD0_DAT1        | I/O  | MFP3  | SD/SDIO0 data line bit 1.                       |
|        |         |         | EMAC_RMII_RXD1  | I    | MFP4  | EMAC RMII Receive Data bus bit 1.               |
|        |         |         | SPI1_CLK        | I/O  | MFP5  | SPI1 serial clock pin.                          |
|        |         |         | UART1_TXD       | O    | MFP6  | UART1 data transmitter output pin.              |
|        |         |         | UART5_nRTS      | O    | MFP7  | UART5 request to Send output pin.               |
|        |         |         | USCI1_DAT1      | I/O  | MFP8  | USCI1 data 1 pin.                               |
|        |         |         | SC0_RST         | O    | MFP9  | Smart Card 0 reset pin.                         |
|        |         |         | I2S0_DI         | I    | MFP10 | I2S0 data input pin.                            |
|        |         |         | EPWM0_CH2       | I/O  | MFP11 | EPWM0 channel 2 output/capture input.           |
|        |         |         | TM2             | I/O  | MFP14 | Timer2 event counter input/toggle output pin.   |
|        |         |         | INT2            | I    | MFP15 | External interrupt 2 input pin.                 |
|        |         |         | PB.2            | I/O  | MFP0  | General purpose digital I/O pin.                |
|        |         |         | EADC0_CH2       | A    | MFP1  | EADC0 channel 2 analog input.                   |
|        |         |         | ACMP0_P1        | A    | MFP1  | Analog comparator 0 positive input 1 pin.       |
|        |         |         | OPA0_O          | A    | MFP1  | Operational amplifier 0 output pin.             |
|        |         |         | EBI_ADR3        | O    | MFP2  | EBI address bus bit 3.                          |
|        |         |         | SD0_DAT0        | I/O  | MFP3  | SD/SDIO0 data line bit 0.                       |
|        |         |         | EMAC_RMII_CRSDV | I    | MFP4  | EMAC RMII Carrier Sense/Receive Data input pin. |
|        |         |         | SPI1_SS         | I/O  | MFP5  | SPI1 slave select pin.                          |
|        |         |         | UART1_RXD       | I    | MFP6  | UART1 data receiver input pin.                  |
|        |         |         | UART5_nCTS      | I    | MFP7  | UART5 clear to Send input pin.                  |
|        |         |         | USCI1_DAT0      | I/O  | MFP8  | USCI1 data 0 pin.                               |
|        |         |         | SC0_PWR         | O    | MFP9  | Smart Card 0 power pin.                         |
|        |         |         | I2S0_DO         | O    | MFP10 | I2S0 data output pin.                           |
|        |         |         | EPWM0_CH3       | I/O  | MFP11 | EPWM0 channel 3 output/capture input.           |
|        |         |         | TM3             | I/O  | MFP14 | Timer3 event counter input/toggle output pin.   |
|        |         |         | INT3            | I    | MFP15 | External interrupt 3 input pin.                 |
|        |         |         | PC.12           | I/O  | MFP0  | General purpose digital I/O pin.                |
|        |         |         | EBI_ADR4        | O    | MFP2  | EBI address bus bit 4.                          |
|        |         |         | UART0_TXD       | O    | MFP3  | UART0 data transmitter output pin.              |
|        |         |         | I2C0_SCL        | I/O  | MFP4  | I2C0 clock pin.                                 |
|        |         |         | SPI3_MISO       | I/O  | MFP6  | SPI3 MISO (Master In, Slave Out) pin.           |
|        |         |         | SC0_nCD         | I    | MFP9  | Smart Card 0 card detect pin.                   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                 |
|--------|---------|---------|-----------------|------|-------|---------------------------------------------|
|        |         |         | ECAP1_IC2       | I    | MFP11 | Enhanced capture unit 1 input 2 pin.        |
|        |         |         | EPWM1_CH0       | I/O  | MFP12 | EPWM1 channel 0 output/capture input.       |
|        |         |         | ACMP0_O         | O    | MFP14 | Analog comparator 0 output pin.             |
|        | 6       | 6       | PC.11           | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_ADR5        | O    | MFP2  | EBI address bus bit 5.                      |
|        |         |         | UART0_RXD       | I    | MFP3  | UART0 data receiver input pin.              |
|        |         |         | I2C0_SDA        | I/O  | MFP4  | I2C0 data input/output pin.                 |
|        |         |         | SPI3_MOSI       | I/O  | MFP6  | SPI3 MOSI (Master Out, Slave In) pin.       |
|        |         |         | ECAP1_IC1       | I    | MFP11 | Enhanced capture unit 1 input 1 pin.        |
|        |         |         | EPWM1_CH1       | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        |         |         | ACMP1_O         | O    | MFP14 | Analog comparator 1 output pin.             |
|        | 7       | 7       | PC.10           | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_ADR6        | O    | MFP2  | EBI address bus bit 6.                      |
|        |         |         | SPI3_CLK        | I/O  | MFP6  | SPI3 serial clock pin.                      |
|        |         |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.          |
|        |         |         | CAN1_TXD        | O    | MFP9  | CAN1 bus transmitter output.                |
|        |         |         | ECAP1_IC0       | I    | MFP11 | Enhanced capture unit 1 input 0 pin.        |
|        |         |         | EPWM1_CH2       | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        | 8       | 8       | PC.9            | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_ADR7        | O    | MFP2  | EBI address bus bit 7.                      |
|        |         |         | SPI3_SS         | I/O  | MFP6  | SPI3 slave select pin.                      |
|        |         |         | UART3_RXD       | I    | MFP7  | UART3 data receiver input pin.              |
|        |         |         | CAN1_RXD        | I    | MFP9  | CAN1 bus receiver input.                    |
|        |         |         | EPWM1_CH3       | I/O  | MFP12 | EPWM1 channel 3 output/capture input.       |
|        | 9       | 9       | PB.1            | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EADC0_CH1       | A    | MFP1  | EADC0 channel 1 analog input.               |
|        |         |         | OPA0_N          | A    | MFP1  | Operational amplifier 0 negative input pin. |
|        |         |         | EBI_ADR8        | O    | MFP2  | EBI address bus bit 8.                      |
|        |         |         | SD0_CLK         | O    | MFP3  | SD/SDIO0 clock output pin                   |
|        |         |         | EMAC_RMII_RXERR | I    | MFP4  | EMAC RMII Receive Data Error input pin.     |
|        |         |         | SPI1_I2SMCLK    | I/O  | MFP5  | SPI1 I2S master clock output pin            |
|        |         |         | SPI3_I2SMCLK    | I/O  | MFP6  | SPI3 I2S master clock output pin            |
|        |         |         | UART2_TXD       | O    | MFP7  | UART2 data transmitter output pin.          |
|        |         |         | USCI1_CLK       | I/O  | MFP8  | USCI1 clock pin.                            |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         |         | I2C1_SCL        | I/O  | MFP9  | I2C1 clock pin.                                                                 |
|        |         |         | I2S0_LRCK       | O    | MFP10 | I2S0 left right channel clock output pin.                                       |
|        |         |         | EPWM0_CH4       | I/O  | MFP11 | EPWM0 channel 4 output/capture input.                                           |
|        |         |         | EPWM1_CH4       | I/O  | MFP12 | EPWM1 channel 4 output/capture input.                                           |
|        |         |         | EPWM0_BRAKE0    | I    | MFP13 | EPWM0 Brake 0 input pin.                                                        |
| 7      | 10      | 10      | PB.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EADC0_CH0       | A    | MFP1  | EADC0 channel 0 analog input.                                                   |
|        |         |         | OPA0_P          | A    | MFP1  | Operational amplifier 0 positive input pin.                                     |
|        |         |         | EBI_ADR9        | O    | MFP2  | EBI address bus bit 9.                                                          |
|        |         |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                   |
|        |         |         | UART2_RXD       | I    | MFP7  | UART2 data receiver input pin.                                                  |
|        |         |         | SPI0_I2SMCLK    | I/O  | MFP8  | SPI0 I2S master clock output pin                                                |
|        |         |         | I2C1_SDA        | I/O  | MFP9  | I2C1 data input/output pin.                                                     |
|        |         |         | EPWM0_CH5       | I/O  | MFP11 | EPWM0 channel 5 output/capture input.                                           |
|        |         |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        | 11      | 11      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |         |         | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 8      | 13      | 13      | PA.11           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | ACMP0_P0        | A    | MFP1  | Analog comparator 0 positive input 0 pin.                                       |
|        |         |         | EBI_nRD         | O    | MFP2  | EBI read enable output pin.                                                     |
|        |         |         | SC2_PWR         | O    | MFP3  | Smart Card 2 power pin.                                                         |
|        |         |         | SPI2_SS         | I/O  | MFP4  | SPI2 slave select pin.                                                          |
|        |         |         | SD1_DAT3        | I/O  | MFP5  | SD/SDIO1 data line bit 3.                                                       |
|        |         |         | USCI0_CLK       | I/O  | MFP6  | USCI0 clock pin.                                                                |
|        |         |         | I2C2_SCL        | I/O  | MFP7  | I2C2 clock pin.                                                                 |
|        |         |         | BPWM0_CH0       | I/O  | MFP9  | BPWM0 channel 0 output/capture input.                                           |
|        |         |         | EPWM0_SYNC_OUT  | O    | MFP10 | EPWM0 counter synchronous trigger output pin.                                   |
|        |         |         | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
|        |         |         | DAC1_ST         | I    | MFP14 | DAC1 external trigger input.                                                    |
| 9      | 14      | 14      | PA.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | ACMP1_P0        | A    | MFP1  | Analog comparator 1 positive input 0 pin.                                       |
|        |         |         | OPA1_O          | A    | MFP1  | Operational amplifier 1 output pin.                                             |

| 64 Pin | 128 Pin | 144 Pin | Pin Name   | Type | MFP   | Description                                      |
|--------|---------|---------|------------|------|-------|--------------------------------------------------|
|        |         |         | EBI_nWR    | O    | MFP2  | EBI write enable output pin.                     |
|        |         |         | SC2_RST    | O    | MFP3  | Smart Card 2 reset pin.                          |
|        |         |         | SPI2_CLK   | I/O  | MFP4  | SPI2 serial clock pin.                           |
|        |         |         | SD1_DAT2   | I/O  | MFP5  | SD/SDIO1 data line bit 2.                        |
|        |         |         | USCI0_DAT0 | I/O  | MFP6  | USCI0 data 0 pin.                                |
|        |         |         | I2C2_SDA   | I/O  | MFP7  | I2C2 data input/output pin.                      |
|        |         |         | BPWM0_CH1  | I/O  | MFP9  | BPWM0 channel 1 output/capture input.            |
|        |         |         | QE1_INDEX  | I    | MFP10 | Quadrature encoder 1 index input                 |
|        |         |         | ECAP0_IC0  | I    | MFP11 | Enhanced capture unit 0 input 0 pin.             |
|        |         |         | TM1_EXT    | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |         |         | DAC0_ST    | I    | MFP14 | DAC0 external trigger input.                     |
|        |         |         | PA.9       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | OPA1_N     | A    | MFP1  | Operational amplifier 1 negative input pin.      |
|        |         |         | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.                   |
|        |         |         | SC2_DAT    | I/O  | MFP3  | Smart Card 2 data pin.                           |
|        |         |         | SPI2_MISO  | I/O  | MFP4  | SPI2 MISO (Master In, Slave Out) pin.            |
|        |         |         | SD1_DAT1   | I/O  | MFP5  | SD/SDIO1 data line bit 1.                        |
|        |         |         | USCI0_DAT1 | I/O  | MFP6  | USCI0 data 1 pin.                                |
|        |         |         | UART1_TXD  | O    | MFP7  | UART1 data transmitter output pin.               |
|        |         |         | BPWM0_CH2  | I/O  | MFP9  | BPWM0 channel 2 output/capture input.            |
|        |         |         | QE1_A      | I    | MFP10 | Quadrature encoder 1 phase A input               |
|        |         |         | ECAP0_IC1  | I    | MFP11 | Enhanced capture unit 0 input 1 pin.             |
|        |         |         | TM2_EXT    | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|        |         |         | PA.8       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | OPA1_P     | A    | MFP1  | Operational amplifier 1 positive input pin.      |
|        |         |         | EBI_ALE    | O    | MFP2  | EBI address latch enable output pin.             |
|        |         |         | SC2_CLK    | O    | MFP3  | Smart Card 2 clock pin.                          |
|        |         |         | SPI2_MOSI  | I/O  | MFP4  | SPI2 MOSI (Master Out, Slave In) pin.            |
|        |         |         | SD1_DAT0   | I/O  | MFP5  | SD/SDIO1 data line bit 0.                        |
|        |         |         | USCI0_CTL1 | I/O  | MFP6  | USCI0 control 1 pin.                             |
|        |         |         | UART1_RXD  | I    | MFP7  | UART1 data receiver input pin.                   |
|        |         |         | BPWM0_CH3  | I/O  | MFP9  | BPWM0 channel 3 output/capture input.            |
|        |         |         | QE1_B      | I    | MFP10 | Quadrature encoder 1 phase B input               |
|        |         |         | ECAP0_IC2  | I    | MFP11 | Enhanced capture unit 0 input 2 pin.             |

| 64 Pin | 128 Pin | 144 Pin | Pin Name     | Type | MFP   | Description                                      |
|--------|---------|---------|--------------|------|-------|--------------------------------------------------|
|        |         |         | TM3_EXT      | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
|        |         |         | INT4         | I    | MFP15 | External interrupt 4 input pin.                  |
|        | 17      | 17      | PC.13        | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | EBI_ADR10    | O    | MFP2  | EBI address bus bit 10.                          |
|        |         |         | SC2_nCD      | I    | MFP3  | Smart Card 2 card detect pin.                    |
|        |         |         | SPI2_I2SMCLK | I/O  | MFP4  | SPI2 I2S master clock output pin                 |
|        |         |         | CAN1_TXD     | O    | MFP5  | CAN1 bus transmitter output.                     |
|        |         |         | USCI0_CTL0   | I/O  | MFP6  | USCI0 control 0 pin.                             |
|        |         |         | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.               |
|        |         |         | BPWM0_CH4    | I/O  | MFP9  | BPWM0 channel 4 output/capture input.            |
|        |         |         | CLKO         | O    | MFP13 | Clock Out                                        |
|        |         |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.                    |
|        | 18      | 18      | PD.12        | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | OPA2_O       | A    | MFP1  | Operational amplifier 2 output pin.              |
|        |         |         | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.                    |
|        |         |         | CAN1_RXD     | I    | MFP5  | CAN1 bus receiver input.                         |
|        |         |         | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.                   |
|        |         |         | BPWM0_CH5    | I/O  | MFP9  | BPWM0 channel 5 output/capture input.            |
|        |         |         | QEIO_INDEX   | I    | MFP10 | Quadrature encoder 0 index input                 |
|        |         |         | CLKO         | O    | MFP13 | Clock Out                                        |
|        |         |         | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.                    |
|        |         |         | INT5         | I    | MFP15 | External interrupt 5 input pin.                  |
|        | 19      | 19      | PD.11        | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | OPA2_N       | A    | MFP1  | Operational amplifier 2 negative input pin.      |
|        |         |         | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.                    |
|        |         |         | UART1_TXD    | O    | MFP3  | UART1 data transmitter output pin.               |
|        |         |         | CAN0_TXD     | O    | MFP4  | CAN0 bus transmitter output.                     |
|        |         |         | QEIO_A       | I    | MFP10 | Quadrature encoder 0 phase A input               |
|        |         |         | INT6         | I    | MFP15 | External interrupt 6 input pin.                  |
|        | 20      | 20      | PD.10        | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | OPA2_P       | A    | MFP1  | Operational amplifier 2 positive input pin.      |
|        |         |         | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.                    |
|        |         |         | UART1_RXD    | I    | MFP3  | UART1 data receiver input pin.                   |
|        |         |         | CAN0_RXD     | I    | MFP4  | CAN0 bus receiver input.                         |

| 64 Pin | 128 Pin | 144 Pin | Pin Name           | Type | MFP   | Description                                                                     |
|--------|---------|---------|--------------------|------|-------|---------------------------------------------------------------------------------|
|        |         |         | QEIO_B             | I    | MFP10 | Quadrature encoder 0 phase B input                                              |
|        |         |         | INT7               | I    | MFP15 | External interrupt 7 input pin.                                                 |
|        |         | 21      | V <sub>ss</sub>    | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |         |         | 22 V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |         |         | 23 PG.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR8           | O    | MFP2  | EBI address bus bit 8.                                                          |
|        |         |         | I2C0_SCL           | I/O  | MFP4  | I2C0 clock pin.                                                                 |
|        |         |         | I2C1_SMBAL         | O    | MFP5  | I2C1 SMBus SMBALTER pin                                                         |
|        |         |         | UART2_RXD          | I    | MFP6  | UART2 data receiver input pin.                                                  |
|        |         |         | CAN1_TXD           | O    | MFP7  | CAN1 bus transmitter output.                                                    |
|        |         |         | UART1_TXD          | O    | MFP8  | UART1 data transmitter output pin.                                              |
|        |         |         | 24 PG.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR9           | O    | MFP2  | EBI address bus bit 9.                                                          |
|        |         |         | SPI2_I2SMCLK       | I/O  | MFP3  | SPI2 I2S master clock output pin                                                |
|        |         |         | I2C0_SDA           | I/O  | MFP4  | I2C0 data input/output pin.                                                     |
|        |         |         | I2C1_SMBSUS        | O    | MFP5  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)                                       |
|        |         |         | UART2_TXD          | O    | MFP6  | UART2 data transmitter output pin.                                              |
|        |         |         | CAN1_RXD           | I    | MFP7  | CAN1 bus receiver input.                                                        |
|        |         |         | UART1_RXD          | I    | MFP8  | UART1 data receiver input pin.                                                  |
|        | 21      |         | 25 PG.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR11          | O    | MFP2  | EBI address bus bit 11.                                                         |
|        |         |         | SPI2_SS            | I/O  | MFP3  | SPI2 slave select pin.                                                          |
|        |         |         | I2C0_SMBAL         | O    | MFP4  | I2C0 SMBus SMBALTER pin                                                         |
|        |         |         | I2C1_SCL           | I/O  | MFP5  | I2C1 clock pin.                                                                 |
|        |         |         | TM0                | I/O  | MFP13 | Timer0 event counter input/toggle output pin.                                   |
|        | 22      |         | 26 PG.3            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR12          | O    | MFP2  | EBI address bus bit 12.                                                         |
|        |         |         | SPI2_CLK           | I/O  | MFP3  | SPI2 serial clock pin.                                                          |
|        |         |         | I2C0_SMBSUS        | O    | MFP4  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)                                       |
|        |         |         | I2C1_SDA           | I/O  | MFP5  | I2C1 data input/output pin.                                                     |
|        |         |         | TM1                | I/O  | MFP13 | Timer1 event counter input/toggle output pin.                                   |
|        | 23      |         | PG.4               | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR13          | O    | MFP2  | EBI address bus bit 13.                                                         |

| 64 Pin | 128 Pin | 144 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|---------|---------|--------------|------|-------|-----------------------------------------------|
|        |         |         | SPI2_MISO    | I/O  | MFP3  | SPI2 MISO (Master In, Slave Out) pin.         |
|        |         |         | TM2          | I/O  | MFP13 | Timer2 event counter input/toggle output pin. |
|        | 24      | 28      | PF.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.                       |
|        |         |         | SPI2_MOSI    | I/O  | MFP3  | SPI2 MOSI (Master Out, Slave In) pin.         |
|        |         |         | TAMPER5      | I/O  | MFP10 | TAMPER detector loop pin 5.                   |
|        |         |         | TM3          | I/O  | MFP13 | Timer3 event counter input/toggle output pin. |
|        | 25      | 29      | PF.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|        |         |         | SC0_nCD      | I    | MFP3  | Smart Card 0 card detect pin.                 |
|        |         |         | I2S0_BCLK    | O    | MFP4  | I2S0 bit clock output pin.                    |
|        |         |         | SPI0_I2SMCLK | I/O  | MFP5  | SPI0 I2S master clock output pin              |
|        |         |         | TAMPER4      | I/O  | MFP10 | TAMPER detector loop pin 4.                   |
|        | 26      | 30      | PF.9         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|        |         |         | SC0_PWR      | O    | MFP3  | Smart Card 0 power pin.                       |
|        |         |         | I2S0_MCLK    | O    | MFP4  | I2S0 master clock output pin.                 |
|        |         |         | SPI0_SS      | I/O  | MFP5  | SPI0 slave select pin.                        |
|        |         |         | TAMPER3      | I/O  | MFP10 | TAMPER detector loop pin 3.                   |
|        | 27      | 31      | PF.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_ADR17    | O    | MFP2  | EBI address bus bit 17.                       |
|        |         |         | SC0_RST      | O    | MFP3  | Smart Card 0 reset pin.                       |
|        |         |         | I2S0_DI      | I    | MFP4  | I2S0 data input pin.                          |
|        |         |         | SPI0_CLK     | I/O  | MFP5  | SPI0 serial clock pin.                        |
|        |         |         | TAMPER2      | I/O  | MFP10 | TAMPER detector loop pin 2.                   |
|        | 28      | 32      | PF.7         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_ADR18    | O    | MFP2  | EBI address bus bit 18.                       |
|        |         |         | SC0_DAT      | I/O  | MFP3  | Smart Card 0 data pin.                        |
|        |         |         | I2S0_DO      | O    | MFP4  | I2S0 data output pin.                         |
|        |         |         | SPI0_MISO    | I/O  | MFP5  | SPI0 MISO (Master In, Slave Out) pin.         |
|        |         |         | UART4_TXD    | O    | MFP6  | UART4 data transmitter output pin.            |
|        |         |         | TAMPER1      | I/O  | MFP10 | TAMPER detector loop pin 1.                   |
|        | 12      | 29      | PF.6         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_ADR19    | O    | MFP2  | EBI address bus bit 19.                       |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         |         | SC0_CLK         | O    | MFP3  | Smart Card 0 clock pin.                                                         |
|        |         |         | I2S0_LRCK       | O    | MFP4  | I2S0 left right channel clock output pin.                                       |
|        |         |         | SPI0_MOSI       | I/O  | MFP5  | SPI0 MOSI (Master Out, Slave In) pin.                                           |
|        |         |         | UART4_RXD       | I    | MFP6  | UART4 data receiver input pin.                                                  |
|        |         |         | EBI_nCS0        | O    | MFP7  | EBI chip select 0 output pin.                                                   |
|        |         |         | TAMPER0         | I/O  | MFP10 | TAMPER detector loop pin 0.                                                     |
| 13     | 30      | 34      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |         |         | PF.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | UART2_RXD       | I    | MFP2  | UART2 data receiver input pin.                                                  |
|        |         |         | UART2_nCTS      | I    | MFP4  | UART2 clear to Send input pin.                                                  |
|        |         |         | BPWM0_CH4       | I/O  | MFP8  | BPWM0 channel 4 output/capture input.                                           |
|        |         |         | EPWM0_SYNC_OUT  | O    | MFP9  | EPWM0 counter synchronous trigger output pin.                                   |
|        |         |         | X32_IN          | I    | MFP10 | External 32.768 kHz crystal input pin.                                          |
|        |         |         | EADC0_ST        | I    | MFP11 | EADC0 external trigger input.                                                   |
|        |         |         | PF.4            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | UART2_TXD       | O    | MFP2  | UART2 data transmitter output pin.                                              |
|        |         |         | UART2_nRTS      | O    | MFP4  | UART2 request to Send output pin.                                               |
|        |         |         | BPWM0_CH5       | I/O  | MFP8  | BPWM0 channel 5 output/capture input.                                           |
|        |         |         | X32_OUT         | O    | MFP10 | External 32.768 kHz crystal output pin.                                         |
|        |         |         | PH.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR7        | O    | MFP2  | EBI address bus bit 7.                                                          |
|        |         |         | UART5_TXD       | O    | MFP4  | UART5 data transmitter output pin.                                              |
|        |         |         | TM0_EXT         | I/O  | MFP13 | Timer0 external capture input/toggle output pin.                                |
|        |         |         | PH.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR6        | O    | MFP2  | EBI address bus bit 6.                                                          |
|        |         |         | UART5_RXD       | I    | MFP4  | UART5 data receiver input pin.                                                  |
|        |         |         | TM1_EXT         | I/O  | MFP13 | Timer1 external capture input/toggle output pin.                                |
|        |         |         | PH.2            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_ADR5        | O    | MFP2  | EBI address bus bit 5.                                                          |
|        |         |         | UART5_nRTS      | O    | MFP4  | UART5 request to Send output pin.                                               |
|        |         |         | UART4_TXD       | O    | MFP5  | UART4 data transmitter output pin.                                              |
|        |         |         | I2C0_SCL        | I/O  | MFP6  | I2C0 clock pin.                                                                 |
|        |         |         | TM2_EXT         | I/O  | MFP13 | Timer2 external capture input/toggle output pin.                                |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type      | MFP   | Description                                                |                                                    |
|--------|---------|---------|-----------------|-----------|-------|------------------------------------------------------------|----------------------------------------------------|
|        |         | 40      | PH.3            | I/O       | MFP0  | General purpose digital I/O pin.                           |                                                    |
|        |         |         | EBI_ADR4        | O         | MFP2  | EBI address bus bit 4.                                     |                                                    |
|        |         |         | SPI1_I2SMCLK    | I/O       | MFP3  | SPI1 I2S master clock output pin                           |                                                    |
|        |         |         | UART5_nCTS      | I         | MFP4  | UART5 clear to Send input pin.                             |                                                    |
|        |         |         | UART4_RXD       | I         | MFP5  | UART4 data receiver input pin.                             |                                                    |
|        |         |         | I2C0_SDA        | I/O       | MFP6  | I2C0 data input/output pin.                                |                                                    |
|        |         |         | TM3_EXT         | I/O       | MFP13 | Timer3 external capture input/toggle output pin.           |                                                    |
|        | 33      | 41      | PH.4            | I/O       | MFP0  | General purpose digital I/O pin.                           |                                                    |
|        |         |         | EBI_ADR3        | O         | MFP2  | EBI address bus bit 3.                                     |                                                    |
|        |         |         | SPI1_MISO       | I/O       | MFP3  | SPI1 MISO (Master In, Slave Out) pin.                      |                                                    |
|        | 34      | 42      | PH.5            | I/O       | MFP0  | General purpose digital I/O pin.                           |                                                    |
|        |         |         | EBI_ADR2        | O         | MFP2  | EBI address bus bit 2.                                     |                                                    |
|        |         |         | SPI1_MOSI       | I/O       | MFP3  | SPI1 MOSI (Master Out, Slave In) pin.                      |                                                    |
|        | 35      | 43      | PH.6            | I/O       | MFP0  | General purpose digital I/O pin.                           |                                                    |
|        |         |         | EBI_ADR1        | O         | MFP2  | EBI address bus bit 1.                                     |                                                    |
|        |         |         | SPI1_CLK        | I/O       | MFP3  | SPI1 serial clock pin.                                     |                                                    |
|        | 36      | 44      | PH.7            | I/O       | MFP0  | General purpose digital I/O pin.                           |                                                    |
|        |         |         | EBI_ADR0        | O         | MFP2  | EBI address bus bit 0.                                     |                                                    |
|        |         |         | SPI1_SS         | I/O       | MFP3  | SPI1 slave select pin.                                     |                                                    |
|        | 16      | 37      | 45              | PF.3      | I/O   | MFP0                                                       | General purpose digital I/O pin.                   |
|        |         |         |                 | EBI_nCS0  | O     | MFP2                                                       | EBI chip select 0 output pin.                      |
|        |         |         |                 | UART0_TXD | O     | MFP3                                                       | UART0 data transmitter output pin.                 |
|        |         |         |                 | I2C0_SCL  | I/O   | MFP4                                                       | I2C0 clock pin.                                    |
|        |         |         |                 | XT1_IN    | I     | MFP10                                                      | External 4~24 MHz (high speed) crystal input pin.  |
|        |         |         |                 | BPWM1_CH0 | I/O   | MFP11                                                      | BPWM1 channel 0 output/capture input.              |
|        | 17      | 38      | 46              | PF.2      | I/O   | MFP0                                                       | General purpose digital I/O pin.                   |
|        |         |         |                 | EBI_nCS1  | O     | MFP2                                                       | EBI chip select 1 output pin.                      |
|        |         |         |                 | UART0_RXD | I     | MFP3                                                       | UART0 data receiver input pin.                     |
|        |         |         |                 | I2C0_SDA  | I/O   | MFP4                                                       | I2C0 data input/output pin.                        |
|        |         |         |                 | QSPI0_CLK | I/O   | MFP5                                                       | Quad SPI0 serial clock pin.                        |
|        |         |         |                 | XT1_OUT   | O     | MFP10                                                      | External 4~24 MHz (high speed) crystal output pin. |
|        |         |         |                 | BPWM1_CH1 | I/O   | MFP11                                                      | BPWM1 channel 1 output/capture input.              |
|        | 39      | 47      | V <sub>ss</sub> | P         | MFP0  | Ground pin for digital circuit.                            |                                                    |
|        | 40      | 48      | V <sub>DD</sub> | P         | MFP0  | Power supply for I/O ports and LDO source for internal PLL |                                                    |

| 64 Pin | 128 Pin | 144 Pin        | Pin Name | Type  | MFP                                        | Description          |
|--------|---------|----------------|----------|-------|--------------------------------------------|----------------------|
|        |         |                |          |       |                                            | and digital circuit. |
| 41     | 49      | PE.8           | I/O      | MFP0  | General purpose digital I/O pin.           |                      |
|        |         | EBI_ADR10      | O        | MFP2  | EBI address bus bit 10.                    |                      |
|        |         | EMAC_RMII_MDC  | O        | MFP3  | EMAC RMII PHY Management Clock output pin. |                      |
|        |         | I2S0_BCLK      | O        | MFP4  | I2S0 bit clock output pin.                 |                      |
|        |         | SPI2_CLK       | I/O      | MFP5  | SPI2 serial clock pin.                     |                      |
|        |         | USCI1_CTL1     | I/O      | MFP6  | USCI1 control 1 pin.                       |                      |
|        |         | UART2_TXD      | O        | MFP7  | UART2 data transmitter output pin.         |                      |
|        |         | EPWM0_CH0      | I/O      | MFP10 | EPWM0 channel 0 output/capture input.      |                      |
|        |         | EPWM0_BRAKE0   | I        | MFP11 | EPWM0 Brake 0 input pin.                   |                      |
|        |         | ECAP0_IC0      | I        | MFP12 | Enhanced capture unit 0 input 0 pin.       |                      |
|        |         | TRACE_CLK      | O        | MFP14 | ETM Trace Clock output pin                 |                      |
| 42     | 50      | PE.9           | I/O      | MFP0  | General purpose digital I/O pin.           |                      |
|        |         | EBI_ADR11      | O        | MFP2  | EBI address bus bit 11.                    |                      |
|        |         | EMAC_RMII_MDIO | I/O      | MFP3  | EMAC RMII PHY Management Data pin.         |                      |
|        |         | I2S0_MCLK      | O        | MFP4  | I2S0 master clock output pin.              |                      |
|        |         | SPI2_MISO      | I/O      | MFP5  | SPI2 MISO (Master In, Slave Out) pin.      |                      |
|        |         | USCI1_CTL0     | I/O      | MFP6  | USCI1 control 0 pin.                       |                      |
|        |         | UART2_RXD      | I        | MFP7  | UART2 data receiver input pin.             |                      |
|        |         | EPWM0_CH1      | I/O      | MFP10 | EPWM0 channel 1 output/capture input.      |                      |
|        |         | EPWM0_BRAKE1   | I        | MFP11 | EPWM0 Brake 1 input pin.                   |                      |
|        |         | ECAP0_IC1      | I        | MFP12 | Enhanced capture unit 0 input 1 pin.       |                      |
|        |         | TRACE_DATA0    | O        | MFP14 | ETM Trace Data 0 output pin                |                      |
| 43     | 51      | PE.10          | I/O      | MFP0  | General purpose digital I/O pin.           |                      |
|        |         | EBI_ADR12      | O        | MFP2  | EBI address bus bit 12.                    |                      |
|        |         | EMAC_RMII_TXD0 | O        | MFP3  | EMAC RMII Transmit Data bus bit 0.         |                      |
|        |         | I2S0_DI        | I        | MFP4  | I2S0 data input pin.                       |                      |
|        |         | SPI2_MOSI      | I/O      | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.      |                      |
|        |         | USCI1_DAT0     | I/O      | MFP6  | USCI1 data 0 pin.                          |                      |
|        |         | UART3_TXD      | O        | MFP7  | UART3 data transmitter output pin.         |                      |
|        |         | EPWM0_CH2      | I/O      | MFP10 | EPWM0 channel 2 output/capture input.      |                      |
|        |         | EPWM1_BRAKE0   | I        | MFP11 | EPWM1 Brake 0 input pin.                   |                      |
|        |         | ECAP0_IC2      | I        | MFP12 | Enhanced capture unit 0 input 2 pin.       |                      |
|        |         | TRACE_DATA1    | O        | MFP14 | ETM Trace Data 1 output pin                |                      |

| 64 Pin | 128 Pin | 144 Pin | Pin Name       | Type | MFP   | Description                               |
|--------|---------|---------|----------------|------|-------|-------------------------------------------|
|        | 44      | 52      | PE.11          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         |         | EBI_ADR13      | O    | MFP2  | EBI address bus bit 13.                   |
|        |         |         | EMAC_RMII_TXD1 | O    | MFP3  | EMAC RMII Transmit Data bus bit 1.        |
|        |         |         | I2S0_DO        | O    | MFP4  | I2S0 data output pin.                     |
|        |         |         | SPI2_SS        | I/O  | MFP5  | SPI2 slave select pin.                    |
|        |         |         | USCI1_DAT1     | I/O  | MFP6  | USCI1 data 1 pin.                         |
|        |         |         | UART3_RXD      | I    | MFP7  | UART3 data receiver input pin.            |
|        |         |         | UART1_nCTS     | I    | MFP8  | UART1 clear to Send input pin.            |
|        |         |         | EPWM0_CH3      | I/O  | MFP10 | EPWM0 channel 3 output/capture input.     |
|        |         |         | EPWM1_BRAKE1   | I    | MFP11 | EPWM1 Brake 1 input pin.                  |
|        |         |         | ECAP1_IC2      | I    | MFP13 | Enhanced capture unit 1 input 2 pin.      |
|        |         |         | TRACE_DATA2    | O    | MFP14 | ETM Trace Data 2 output pin               |
|        | 45      | 53      | PE.12          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         |         | EBI_ADR14      | O    | MFP2  | EBI address bus bit 14.                   |
|        |         |         | EMAC_RMII_TXEN | O    | MFP3  | EMAC RMII Transmit Enable output pin.     |
|        |         |         | I2S0_LRCK      | O    | MFP4  | I2S0 left right channel clock output pin. |
|        |         |         | SPI2_I2SMCLK   | I/O  | MFP5  | SPI2 I2S master clock output pin          |
|        |         |         | USCI1_CLK      | I/O  | MFP6  | USCI1 clock pin.                          |
|        |         |         | UART1_nRTS     | O    | MFP8  | UART1 request to Send output pin.         |
|        |         |         | EPWM0_CH4      | I/O  | MFP10 | EPWM0 channel 4 output/capture input.     |
|        |         |         | ECAP1_IC1      | I    | MFP13 | Enhanced capture unit 1 input 1 pin.      |
|        |         |         | TRACE_DATA3    | O    | MFP14 | ETM Trace Data 3 output pin               |
|        | 46      | 54      | PE.13          | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         |         | EBI_ADR15      | O    | MFP2  | EBI address bus bit 15.                   |
|        |         |         | EMAC_PPS       | O    | MFP3  | EMAC Pulse Per Second output pin.         |
|        |         |         | I2C0_SCL       | I/O  | MFP4  | I2C0 clock pin.                           |
|        |         |         | UART4_nRTS     | O    | MFP5  | UART4 request to Send output pin.         |
|        |         |         | UART1_TXD      | O    | MFP8  | UART1 data transmitter output pin.        |
|        |         |         | EPWM0_CH5      | I/O  | MFP10 | EPWM0 channel 5 output/capture input.     |
|        |         |         | EPWM1_CH0      | I/O  | MFP11 | EPWM1 channel 0 output/capture input.     |
|        |         |         | BPWM1_CH5      | I/O  | MFP12 | BPWM1 channel 5 output/capture input.     |
|        |         |         | ECAP1_IC0      | I    | MFP13 | Enhanced capture unit 1 input 0 pin.      |
|        | 47      | 55      | PC.8           | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         |         | EBI_ADR16      | O    | MFP2  | EBI address bus bit 16.                   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name         | Type | MFP   | Description                                     |
|--------|---------|---------|------------------|------|-------|-------------------------------------------------|
|        |         |         | EMAC_RMII_REFCLK | I    | MFP3  | EMAC RMII reference clock input pin.            |
|        |         |         | I2C0_SDA         | I/O  | MFP4  | I2C0 data input/output pin.                     |
|        |         |         | UART4_nCTS       | I    | MFP5  | UART4 clear to Send input pin.                  |
|        |         |         | UART1_RXD        | I    | MFP8  | UART1 data receiver input pin.                  |
|        |         |         | EPWM1_CH1        | I/O  | MFP11 | EPWM1 channel 1 output/capture input.           |
|        |         |         | BPWM1_CH4        | I/O  | MFP12 | BPWM1 channel 4 output/capture input.           |
|        |         |         | PC.7             | I/O  | MFP0  | General purpose digital I/O pin.                |
|        |         |         | EBI_AD9          | I/O  | MFP2  | EBI address/data bus bit 9.                     |
|        |         |         | EMAC_RMII_RXD0   | I    | MFP3  | EMAC RMII Receive Data bus bit 0.               |
|        |         |         | SPI1_MISO        | I/O  | MFP4  | SPI1 MISO (Master In, Slave Out) pin.           |
|        |         |         | UART4_TXD        | O    | MFP5  | UART4 data transmitter output pin.              |
|        |         |         | SC2_PWR          | O    | MFP6  | Smart Card 2 power pin.                         |
|        |         |         | UART0_nCTS       | I    | MFP7  | UART0 clear to Send input pin.                  |
|        |         |         | I2C1_SMBAL       | O    | MFP8  | I2C1 SMBus SMBALTER pin                         |
|        |         |         | EPWM1_CH2        | I/O  | MFP11 | EPWM1 channel 2 output/capture input.           |
|        |         |         | BPWM1_CH0        | I/O  | MFP12 | BPWM1 channel 0 output/capture input.           |
|        |         |         | TM0              | I/O  | MFP14 | Timer0 event counter input/toggle output pin.   |
|        |         |         | INT3             | I    | MFP15 | External interrupt 3 input pin.                 |
|        |         |         | PC.6             | I/O  | MFP0  | General purpose digital I/O pin.                |
|        |         |         | EBI_AD8          | I/O  | MFP2  | EBI address/data bus bit 8.                     |
|        |         |         | EMAC_RMII_RXD1   | I    | MFP3  | EMAC RMII Receive Data bus bit 1.               |
|        |         |         | SPI1_MOSI        | I/O  | MFP4  | SPI1 MOSI (Master Out, Slave In) pin.           |
|        |         |         | UART4_RXD        | I    | MFP5  | UART4 data receiver input pin.                  |
|        |         |         | SC2_RST          | O    | MFP6  | Smart Card 2 reset pin.                         |
|        |         |         | UART0_nRTS       | O    | MFP7  | UART0 request to Send output pin.               |
|        |         |         | I2C1_SMBSUS      | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)       |
|        |         |         | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.           |
|        |         |         | BPWM1_CH1        | I/O  | MFP12 | BPWM1 channel 1 output/capture input.           |
|        |         |         | TM1              | I/O  | MFP14 | Timer1 event counter input/toggle output pin.   |
|        |         |         | INT2             | I    | MFP15 | External interrupt 2 input pin.                 |
|        |         |         | PA.7             | I/O  | MFP0  | General purpose digital I/O pin.                |
|        |         |         | EBI_AD7          | I/O  | MFP2  | EBI address/data bus bit 7.                     |
|        |         |         | EMAC_RMII_CRSDV  | I    | MFP3  | EMAC RMII Carrier Sense/Receive Data input pin. |
|        |         |         | SPI1_CLK         | I/O  | MFP4  | SPI1 serial clock pin.                          |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         |         | SC2_DAT         | I/O  | MFP6  | Smart Card 2 data pin.                                                          |
|        |         |         | UART0_TXD       | O    | MFP7  | UART0 data transmitter output pin.                                              |
|        |         |         | I2C1_SCL        | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |         |         | EPWM1_CH4       | I/O  | MFP11 | EPWM1 channel 4 output/capture input.                                           |
|        |         |         | BPWM1_CH2       | I/O  | MFP12 | BPWM1 channel 2 output/capture input.                                           |
|        |         |         | ACMP0_WLAT      | I    | MFP13 | Analog comparator 0 window latch input pin                                      |
|        |         |         | TM2             | I/O  | MFP14 | Timer2 event counter input/toggle output pin.                                   |
|        |         |         | INT1            | I    | MFP15 | External interrupt 1 input pin.                                                 |
| 21     | 51      | 59      | PA.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD6         | I/O  | MFP2  | EBI address/data bus bit 6.                                                     |
|        |         |         | EMAC_RMII_RXERR | I    | MFP3  | EMAC RMII Receive Data Error input pin.                                         |
|        |         |         | SPI1_SS         | I/O  | MFP4  | SPI1 slave select pin.                                                          |
|        |         |         | SD1_nCD         | I    | MFP5  | SD/SDIO1 card detect input pin                                                  |
|        |         |         | SC2_CLK         | O    | MFP6  | Smart Card 2 clock pin.                                                         |
|        |         |         | UART0_RXD       | I    | MFP7  | UART0 data receiver input pin.                                                  |
|        |         |         | I2C1_SDA        | I/O  | MFP8  | I2C1 data input/output pin.                                                     |
|        |         |         | EPWM1_CH5       | I/O  | MFP11 | EPWM1 channel 5 output/capture input.                                           |
|        |         |         | BPWM1_CH3       | I/O  | MFP12 | BPWM1 channel 3 output/capture input.                                           |
|        |         |         | ACMP1_WLAT      | I    | MFP13 | Analog comparator 1 window latch input pin                                      |
|        |         |         | TM3             | I/O  | MFP14 | Timer3 event counter input/toggle output pin.                                   |
|        |         |         | INT0            | I    | MFP15 | External interrupt 0 input pin.                                                 |
| 22     | 52      | 60      | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 23     | 53      | 61      | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 24     | 54      | 62      | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |
| 25     | 55      | 63      | PA.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | SPIM_D2         | I/O  | MFP2  | SPIM data 2 pin for Quad Mode I/O.                                              |
|        |         |         | QSPI0_MISO1     | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin.                                     |
|        |         |         | SPI1_I2SMCLK    | I/O  | MFP4  | SPI1 I2S master clock output pin                                                |
|        |         |         | SD1_CMD         | I/O  | MFP5  | SD/SDIO1 command/response pin                                                   |
|        |         |         | SC2_nCD         | I    | MFP6  | Smart Card 2 card detect pin.                                                   |
|        |         |         | UART0_nCTS      | I    | MFP7  | UART0 clear to Send input pin.                                                  |
|        |         |         | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.                                              |
|        |         |         | I2C0_SCL        | I/O  | MFP9  | I2C0 clock pin.                                                                 |

| 64 Pin | 128 Pin | 144 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|---------|---------|--------------|------|-------|---------------------------------------------|
|        |         |         | CAN0_TXD     | O    | MFP10 | CAN0 bus transmitter output.                |
|        |         |         | BPWM0_CH5    | I/O  | MFP12 | BPWM0 channel 5 output/capture input.       |
|        |         |         | EPWM0_CH0    | I/O  | MFP13 | EPWM0 channel 0 output/capture input.       |
|        |         |         | QEIO_INDEX   | I    | MFP14 | Quadrature encoder 0 index input            |
| 26     | 56      | 64      | PA.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | SPIIM_D3     | I/O  | MFP2  | SPIIM data 3 pin for Quad Mode I/O.         |
|        |         |         | QSPI0_MOSI1  | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |         |         | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin            |
|        |         |         | SD1_CLK      | O    | MFP5  | SD/SDIO1 clock output pin                   |
|        |         |         | SC0_nCD      | I    | MFP6  | Smart Card 0 card detect pin.               |
|        |         |         | UART0_nRTS   | O    | MFP7  | UART0 request to Send output pin.           |
|        |         |         | UART5_RXD    | I    | MFP8  | UART5 data receiver input pin.              |
|        |         |         | I2C0_SDA     | I/O  | MFP9  | I2C0 data input/output pin.                 |
|        |         |         | CAN0_RXD     | I    | MFP10 | CAN0 bus receiver input.                    |
|        |         |         | BPWM0_CH4    | I/O  | MFP12 | BPWM0 channel 4 output/capture input.       |
|        |         |         | EPWM0_CH1    | I/O  | MFP13 | EPWM0 channel 1 output/capture input.       |
| 27     | 57      | 65      | QEIO_A       | I    | MFP14 | Quadrature encoder 0 phase A input          |
|        |         |         | PA.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | SPIIM_SS     | I/O  | MFP2  | SPIIM slave select pin.                     |
|        |         |         | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                 |
|        |         |         | SPI0_SS      | I/O  | MFP4  | SPI0 slave select pin.                      |
|        |         |         | SD1_DAT3     | I/O  | MFP5  | SD/SDIO1 data line bit 3.                   |
|        |         |         | SC0_PWR      | O    | MFP6  | Smart Card 0 power pin.                     |
|        |         |         | UART4_TXD    | O    | MFP7  | UART4 data transmitter output pin.          |
|        |         |         | UART1_TXD    | O    | MFP8  | UART1 data transmitter output pin.          |
|        |         |         | I2C1_SCL     | I/O  | MFP9  | I2C1 clock pin.                             |
|        |         |         | BPWM0_CH3    | I/O  | MFP12 | BPWM0 channel 3 output/capture input.       |
|        |         |         | EPWM0_CH2    | I/O  | MFP13 | EPWM0 channel 2 output/capture input.       |
| 28     | 58      | 66      | QEIO_B       | I    | MFP14 | Quadrature encoder 0 phase B input          |
|        |         |         | PA.2         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | SPIIM_CLK    | I/O  | MFP2  | SPIIM serial clock pin.                     |
|        |         |         | QSPI0_CLK    | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|        |         |         | SPI0_CLK     | I/O  | MFP4  | SPI0 serial clock pin.                      |
|        |         |         | SD1_DAT2     | I/O  | MFP5  | SD/SDIO1 data line bit 2.                   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name          | Type | MFP   | Description                                 |
|--------|---------|---------|-------------------|------|-------|---------------------------------------------|
|        |         |         | SC0_RST           | O    | MFP6  | Smart Card 0 reset pin.                     |
|        |         |         | UART4_RXD         | I    | MFP7  | UART4 data receiver input pin.              |
|        |         |         | UART1_RXD         | I    | MFP8  | UART1 data receiver input pin.              |
|        |         |         | I2C1_SDA          | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |         |         | BPWM0_CH2         | I/O  | MFP12 | BPWM0 channel 2 output/capture input.       |
|        |         |         | EPWM0_CH3         | I/O  | MFP13 | EPWM0 channel 3 output/capture input.       |
|        |         |         | PA.1              | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | SPIIM_MISO        | I/O  | MFP2  | SPIIM MISO (Master In, Slave Out) pin.      |
|        |         |         | QSPI0_MISO0       | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|        |         |         | SPI0_MISO         | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|        |         |         | SD1_DAT1          | I/O  | MFP5  | SD/SDIO1 data line bit 1.                   |
|        |         |         | SC0_DAT           | I/O  | MFP6  | Smart Card 0 data pin.                      |
|        |         |         | UART0_TXD         | O    | MFP7  | UART0 data transmitter output pin.          |
|        |         |         | UART1_nCTS        | I    | MFP8  | UART1 clear to Send input pin.              |
|        |         |         | I2C2_SCL          | I/O  | MFP9  | I2C2 clock pin.                             |
|        |         |         | BPWM0_CH1         | I/O  | MFP12 | BPWM0 channel 1 output/capture input.       |
|        |         |         | EPWM0_CH4         | I/O  | MFP13 | EPWM0 channel 4 output/capture input.       |
|        |         |         | DAC1_ST           | I    | MFP15 | DAC1 external trigger input.                |
|        |         |         | PA.0              | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | SPIIM_MOSI        | I/O  | MFP2  | SPIIM MOSI (Master Out, Slave In) pin.      |
|        |         |         | QSPI0_MOSI0       | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|        |         |         | SPI0_MOSI         | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.       |
|        |         |         | SD1_DAT0          | I/O  | MFP5  | SD/SDIO1 data line bit 0.                   |
|        |         |         | SC0_CLK           | O    | MFP6  | Smart Card 0 clock pin.                     |
|        |         |         | UART0_RXD         | I    | MFP7  | UART0 data receiver input pin.              |
|        |         |         | UART1_nRTS        | O    | MFP8  | UART1 request to Send output pin.           |
|        |         |         | I2C2_SDA          | I/O  | MFP9  | I2C2 data input/output pin.                 |
|        |         |         | BPWM0_CH0         | I/O  | MFP12 | BPWM0 channel 0 output/capture input.       |
|        |         |         | EPWM0_CH5         | I/O  | MFP13 | EPWM0 channel 5 output/capture input.       |
|        |         |         | DAC0_ST           | I    | MFP15 | DAC0 external trigger input.                |
| 31     | 61      | 69      | V <sub>DDIO</sub> | P    | MFP0  | Power supply for PA.0~PA.5.                 |
|        |         |         | PE.14             | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_AD8           | I/O  | MFP2  | EBI address/data bus bit 8.                 |
|        |         |         | UART2_TXD         | O    | MFP3  | UART2 data transmitter output pin.          |

| 64 Pin | 128 Pin | 144 Pin | Pin Name    | Type | MFP   | Description                                                                                          |
|--------|---------|---------|-------------|------|-------|------------------------------------------------------------------------------------------------------|
|        |         |         | CAN0_TXD    | O    | MFP4  | CAN0 bus transmitter output.                                                                         |
|        |         |         | SD1_nCD     | I    | MFP5  | SD/SDIO1 card detect input pin                                                                       |
|        | 63      | 71      | PE.15       | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         |         | EBI_AD9     | I/O  | MFP2  | EBI address/data bus bit 9.                                                                          |
|        |         |         | UART2_RXD   | I    | MFP3  | UART2 data receiver input pin.                                                                       |
|        |         |         | CAN0_RXD    | I    | MFP4  | CAN0 bus receiver input.                                                                             |
| 32     | 64      | 72      | nRESET      | I    | MFP0  | External reset input: active LOW, with an internal pull-up. Set this pin low reset to initial state. |
|        | 65      | 73      | PF.0        | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         |         | UART1_TXD   | O    | MFP2  | UART1 data transmitter output pin.                                                                   |
|        |         |         | I2C1_SCL    | I/O  | MFP3  | I2C1 clock pin.                                                                                      |
|        |         |         | BPWM1_CH0   | I/O  | MFP12 | BPWM1 channel 0 output/capture input.                                                                |
|        |         |         | ICE_DAT     | O    | MFP14 | Serial wired debugger data pin.                                                                      |
|        | 66      | 74      | PF.1        | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         |         | UART1_RXD   | I    | MFP2  | UART1 data receiver input pin.                                                                       |
|        |         |         | I2C1_SDA    | I/O  | MFP3  | I2C1 data input/output pin.                                                                          |
|        |         |         | BPWM1_CH1   | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                                                                |
|        |         |         | ICE_CLK     | I    | MFP14 | Serial wired debugger clock pin.                                                                     |
|        | 67      | 75      | PD.9        | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         |         | EBI_AD7     | I/O  | MFP2  | EBI address/data bus bit 7.                                                                          |
|        |         |         | I2C2_SCL    | I/O  | MFP3  | I2C2 clock pin.                                                                                      |
|        |         |         | UART2_nCTS  | I    | MFP4  | UART2 clear to Send input pin.                                                                       |
|        | 68      | 76      | PD.8        | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         |         | EBI_AD6     | I/O  | MFP2  | EBI address/data bus bit 6.                                                                          |
|        |         |         | I2C2_SDA    | I/O  | MFP3  | I2C2 data input/output pin.                                                                          |
|        |         |         | UART2_nRTS  | O    | MFP4  | UART2 request to Send output pin.                                                                    |
|        | 69      | 77      | PC.5        | I/O  | MFP0  | General purpose digital I/O pin.                                                                     |
|        |         |         | EBI_AD5     | I/O  | MFP2  | EBI address/data bus bit 5.                                                                          |
|        |         |         | SPIM_D2     | I/O  | MFP3  | SPIM data 2 pin for Quad Mode I/O.                                                                   |
|        |         |         | QSPI0_MISO1 | I/O  | MFP4  | Quad SPI0 MISO1 (Master In, Slave Out) pin.                                                          |
|        |         |         | UART2_TXD   | O    | MFP8  | UART2 data transmitter output pin.                                                                   |
|        |         |         | I2C1_SCL    | I/O  | MFP9  | I2C1 clock pin.                                                                                      |
|        |         |         | CAN0_TXD    | O    | MFP10 | CAN0 bus transmitter output.                                                                         |
|        |         |         | UART4_TXD   | O    | MFP11 | UART4 data transmitter output pin.                                                                   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|---------|---------|--------------|------|-------|---------------------------------------------|
|        |         |         | EPWM1_CH0    | I/O  | MFP12 | EPWM1 channel 0 output/capture input.       |
| 36     | 70      | 78      | PC.4         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_AD4      | I/O  | MFP2  | EBI address/data bus bit 4.                 |
|        |         |         | SPIIM_D3     | I/O  | MFP3  | SPIIM data 3 pin for Quad Mode I/O.         |
|        |         |         | QSPI0_MOSI1  | I/O  | MFP4  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |         |         | SC1_nCD      | I    | MFP5  | Smart Card 1 card detect pin.               |
|        |         |         | I2S0_BCLK    | O    | MFP6  | I2S0 bit clock output pin.                  |
|        |         |         | SPI1_I2SMCLK | I/O  | MFP7  | SPI1 I2S master clock output pin            |
|        |         |         | UART2_RXD    | I    | MFP8  | UART2 data receiver input pin.              |
|        |         |         | I2C1_SDA     | I/O  | MFP9  | I2C1 data input/output pin.                 |
|        |         |         | CAN0_RXD     | I    | MFP10 | CAN0 bus receiver input.                    |
| 37     | 71      | 79      | UART4_RXD    | I    | MFP11 | UART4 data receiver input pin.              |
|        |         |         | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.       |
|        |         |         | PC.3         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_AD3      | I/O  | MFP2  | EBI address/data bus bit 3.                 |
|        |         |         | SPIIM_SS     | I/O  | MFP3  | SPIIM slave select pin.                     |
|        |         |         | QSPI0_SS     | I/O  | MFP4  | Quad SPI0 slave select pin.                 |
|        |         |         | SC1_PWR      | O    | MFP5  | Smart Card 1 power pin.                     |
|        |         |         | I2S0_MCLK    | O    | MFP6  | I2S0 master clock output pin.               |
|        |         |         | SPI1_MISO    | I/O  | MFP7  | SPI1 MISO (Master In, Slave Out) pin.       |
|        |         |         | UART2_nRTS   | O    | MFP8  | UART2 request to Send output pin.           |
| 38     | 72      | 80      | I2C0_SMBAL   | O    | MFP9  | I2C0 SMBus SMBALTER pin                     |
|        |         |         | CAN1_TXD     | O    | MFP10 | CAN1 bus transmitter output.                |
|        |         |         | UART3_TXD    | O    | MFP11 | UART3 data transmitter output pin.          |
|        |         |         | EPWM1_CH2    | I/O  | MFP12 | EPWM1 channel 2 output/capture input.       |
|        |         |         | PC.2         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_AD2      | I/O  | MFP2  | EBI address/data bus bit 2.                 |
|        |         |         | SPIIM_CLK    | I/O  | MFP3  | SPIIM serial clock pin.                     |
|        |         |         | QSPI0_CLK    | I/O  | MFP4  | Quad SPI0 serial clock pin.                 |
|        |         |         | SC1_RST      | O    | MFP5  | Smart Card 1 reset pin.                     |
|        |         |         | I2S0_DI      | I    | MFP6  | I2S0 data input pin.                        |
| 39     | 73      | 81      | SPI1_MOSI    | I/O  | MFP7  | SPI1 MOSI (Master Out, Slave In) pin.       |
|        |         |         | UART2_nCTS   | I    | MFP8  | UART2 clear to Send input pin.              |
| 40     | 74      | 82      | I2C0_SMBSUS  | O    | MFP9  | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin)   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         |         | CAN1_RXD        | I    | MFP10 | CAN1 bus receiver input.                                                        |
|        |         |         | UART3_RXD       | I    | MFP11 | UART3 data receiver input pin.                                                  |
|        |         |         | EPWM1_CH3       | I/O  | MFP12 | EPWM1 channel 3 output/capture input.                                           |
| 39     | 73      | 81      | PC.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD1         | I/O  | MFP2  | EBI address/data bus bit 1.                                                     |
|        |         |         | SPIM_MISO       | I/O  | MFP3  | SPIM MISO (Master In, Slave Out) pin.                                           |
|        |         |         | QSPI0_MISO0     | I/O  | MFP4  | Quad SPI0 MISO0 (Master In, Slave Out) pin.                                     |
|        |         |         | SC1_DAT         | I/O  | MFP5  | Smart Card 1 data pin.                                                          |
|        |         |         | I2S0_DO         | O    | MFP6  | I2S0 data output pin.                                                           |
|        |         |         | SPI1_CLK        | I/O  | MFP7  | SPI1 serial clock pin.                                                          |
|        |         |         | UART2_TXD       | O    | MFP8  | UART2 data transmitter output pin.                                              |
|        |         |         | I2C0_SCL        | I/O  | MFP9  | I2C0 clock pin.                                                                 |
|        |         |         | EPWM1_CH4       | I/O  | MFP12 | EPWM1 channel 4 output/capture input.                                           |
| 40     | 74      | 82      | ACMP0_O         | O    | MFP14 | Analog comparator 0 output pin.                                                 |
|        |         |         | PC.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD0         | I/O  | MFP2  | EBI address/data bus bit 0.                                                     |
|        |         |         | SPIM_MOSI       | I/O  | MFP3  | SPIM MOSI (Master Out, Slave In) pin.                                           |
|        |         |         | QSPI0_MOSI0     | I/O  | MFP4  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.                                     |
|        |         |         | SC1_CLK         | O    | MFP5  | Smart Card 1 clock pin.                                                         |
|        |         |         | I2S0_LRCK       | O    | MFP6  | I2S0 left right channel clock output pin.                                       |
|        |         |         | SPI1_SS         | I/O  | MFP7  | SPI1 slave select pin.                                                          |
|        |         |         | UART2_RXD       | I    | MFP8  | UART2 data receiver input pin.                                                  |
|        |         |         | I2C0_SDA        | I/O  | MFP9  | I2C0 data input/output pin.                                                     |
|        |         |         | EPWM1_CH5       | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                                           |
|        |         |         | ACMP1_O         | O    | MFP14 | Analog comparator 1 output pin.                                                 |
|        |         |         | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        |         |         | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |         |         | PG.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD0         | I/O  | MFP2  | EBI address/data bus bit 0.                                                     |
|        |         |         | SD1_DAT3        | I/O  | MFP3  | SD/SDIO1 data line bit 3.                                                       |
|        |         |         | SPIM_D2         | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.                                              |
|        |         |         | BPWM0_CH5       | I/O  | MFP12 | BPWM0 channel 5 output/capture input.                                           |
|        |         |         | PG.10           | I/O  | MFP0  | General purpose digital I/O pin.                                                |

| 64 Pin | 128 Pin | 144 Pin | Pin Name   | Type | MFP   | Description                            |
|--------|---------|---------|------------|------|-------|----------------------------------------|
|        |         |         | EBI_AD1    | I/O  | MFP2  | EBI address/data bus bit 1.            |
|        |         |         | SD1_DAT2   | I/O  | MFP3  | SD/SDIO1 data line bit 2.              |
|        |         |         | SPI_M_D3   | I/O  | MFP4  | SPI_M data 3 pin for Quad Mode I/O.    |
|        |         |         | BPWM0_CH4  | I/O  | MFP12 | BPWM0 channel 4 output/capture input.  |
|        |         | 79      | PG.11      | I/O  | MFP0  | General purpose digital I/O pin.       |
|        |         |         | EBI_AD2    | I/O  | MFP2  | EBI address/data bus bit 2.            |
|        |         |         | SD1_DAT1   | I/O  | MFP3  | SD/SDIO1 data line bit 1.              |
|        |         |         | SPI_M_SS   | I/O  | MFP4  | SPI_M slave select pin.                |
|        |         |         | BPWM0_CH3  | I/O  | MFP12 | BPWM0 channel 3 output/capture input.  |
|        |         | 80      | PG.12      | I/O  | MFP0  | General purpose digital I/O pin.       |
|        |         |         | EBI_AD3    | I/O  | MFP2  | EBI address/data bus bit 3.            |
|        |         |         | SD1_DAT0   | I/O  | MFP3  | SD/SDIO1 data line bit 0.              |
|        |         |         | SPI_M_CLK  | I/O  | MFP4  | SPI_M serial clock pin.                |
|        |         |         | BPWM0_CH2  | I/O  | MFP12 | BPWM0 channel 2 output/capture input.  |
|        |         | 81      | PG.13      | I/O  | MFP0  | General purpose digital I/O pin.       |
|        |         |         | EBI_AD4    | I/O  | MFP2  | EBI address/data bus bit 4.            |
|        |         |         | SD1_CMD    | I/O  | MFP3  | SD/SDIO1 command/response pin          |
|        |         |         | SPI_M_MISO | I/O  | MFP4  | SPI_M MISO (Master In, Slave Out) pin. |
|        |         |         | BPWM0_CH1  | I/O  | MFP12 | BPWM0 channel 1 output/capture input.  |
|        |         | 82      | PG.14      | I/O  | MFP0  | General purpose digital I/O pin.       |
|        |         |         | EBI_AD5    | I/O  | MFP2  | EBI address/data bus bit 5.            |
|        |         |         | SD1_CLK    | O    | MFP3  | SD/SDIO1 clock output pin              |
|        |         |         | SPI_M_MOSI | I/O  | MFP4  | SPI_M MOSI (Master Out, Slave In) pin. |
|        |         |         | BPWM0_CH0  | I/O  | MFP12 | BPWM0 channel 0 output/capture input.  |
|        |         | 83      | PG.15      | I/O  | MFP0  | General purpose digital I/O pin.       |
|        |         |         | SD1_nCD    | I    | MFP3  | SD/SDIO1 card detect input pin         |
|        |         |         | CLK_O      | O    | MFP14 | Clock Out                              |
|        |         |         | EADC0_ST   | I    | MFP15 | EADC0 external trigger input.          |
|        |         | 92      | PD.3       | I/O  | MFP0  | General purpose digital I/O pin.       |
|        |         |         | EBI_AD10   | I/O  | MFP2  | EBI address/data bus bit 10.           |
|        |         |         | USCI0_CTL1 | I/O  | MFP3  | USCI0 control 1 pin.                   |
|        |         |         | SPI0_SS    | I/O  | MFP4  | SPI0 slave select pin.                 |
|        |         |         | UART3_nRTS | O    | MFP5  | UART3 request to Send output pin.      |
|        |         |         | USCI1_CTL0 | I/O  | MFP6  | USCI1 control 0 pin.                   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name     | Type | MFP   | Description                                   |
|--------|---------|---------|--------------|------|-------|-----------------------------------------------|
|        |         |         | SC2_PWR      | O    | MFP7  | Smart Card 2 power pin.                       |
|        |         |         | SC1_nCD      | I    | MFP8  | Smart Card 1 card detect pin.                 |
|        |         |         | UART0_TXD    | O    | MFP9  | UART0 data transmitter output pin.            |
|        |         | 93      | PD.2         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_AD11     | I/O  | MFP2  | EBI address/data bus bit 11.                  |
|        |         |         | USCI0_DAT1   | I/O  | MFP3  | USCI0 data 1 pin.                             |
|        |         |         | SPI0_CLK     | I/O  | MFP4  | SPI0 serial clock pin.                        |
|        |         |         | UART3_nCTS   | I    | MFP5  | UART3 clear to Send input pin.                |
|        |         |         | SC2_RST      | O    | MFP7  | Smart Card 2 reset pin.                       |
|        |         |         | UART0_RXD    | I    | MFP9  | UART0 data receiver input pin.                |
|        |         | 94      | PD.1         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_AD12     | I/O  | MFP2  | EBI address/data bus bit 12.                  |
|        |         |         | USCI0_DAT0   | I/O  | MFP3  | USCI0 data 0 pin.                             |
|        |         |         | SPI0_MISO    | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.         |
|        |         |         | UART3_TXD    | O    | MFP5  | UART3 data transmitter output pin.            |
|        |         |         | I2C2_SCL     | I/O  | MFP6  | I2C2 clock pin.                               |
|        |         |         | SC2_DAT      | I/O  | MFP7  | Smart Card 2 data pin.                        |
|        |         | 95      | PD.0         | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_AD13     | I/O  | MFP2  | EBI address/data bus bit 13.                  |
|        |         |         | USCI0_CLK    | I/O  | MFP3  | USCI0 clock pin.                              |
|        |         |         | SPI0_MOSI    | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.         |
|        |         |         | UART3_RXD    | I    | MFP5  | UART3 data receiver input pin.                |
|        |         |         | I2C2_SDA     | I/O  | MFP6  | I2C2 data input/output pin.                   |
|        |         |         | SC2_CLK      | O    | MFP7  | Smart Card 2 clock pin.                       |
|        |         |         | TM2          | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|        |         | 96      | PD.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | EBI_AD10     | I/O  | MFP2  | EBI address/data bus bit 10.                  |
|        |         |         | SD0_nCD      | I    | MFP3  | SD/SDIO0 card detect input pin                |
|        |         |         | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I2S master clock output pin              |
|        |         |         | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I2S master clock output pin              |
|        |         |         | SC2_nCD      | I    | MFP7  | Smart Card 2 card detect pin.                 |
|        |         | 97      | PA.12        | I/O  | MFP0  | General purpose digital I/O pin.              |
|        |         |         | I2S0_BCLK    | O    | MFP2  | I2S0 bit clock output pin.                    |
|        |         |         | UART4_TXD    | O    | MFP3  | UART4 data transmitter output pin.            |

| 64 Pin | 128 Pin | 144 Pin | Pin Name      | Type | MFP   | Description                                  |
|--------|---------|---------|---------------|------|-------|----------------------------------------------|
|        |         |         | I2C1_SCL      | I/O  | MFP4  | I2C1 clock pin.                              |
|        |         |         | SPI2_SS       | I/O  | MFP5  | SPI2 slave select pin.                       |
|        |         |         | CAN0_TXD      | O    | MFP6  | CAN0 bus transmitter output.                 |
|        |         |         | SC2_PWR       | O    | MFP7  | Smart Card 2 power pin.                      |
|        |         |         | BPWM1_CH2     | I/O  | MFP11 | BPWM1 channel 2 output/capture input.        |
|        |         |         | QEI1_INDEX    | I    | MFP12 | Quadrature encoder 1 index input             |
|        |         |         | USB_VBUS      | P    | MFP14 | Power supply from USB host or HUB.           |
|        |         | 98      | PA.13         | I/O  | MFP0  | General purpose digital I/O pin.             |
|        |         |         | I2S0_MCLK     | O    | MFP2  | I2S0 master clock output pin.                |
|        |         |         | UART4_RXD     | I    | MFP3  | UART4 data receiver input pin.               |
|        |         |         | I2C1_SDA      | I/O  | MFP4  | I2C1 data input/output pin.                  |
|        |         |         | SPI2_CLK      | I/O  | MFP5  | SPI2 serial clock pin.                       |
|        |         |         | CAN0_RXD      | I    | MFP6  | CAN0 bus receiver input.                     |
|        |         |         | SC2_RST       | O    | MFP7  | Smart Card 2 reset pin.                      |
|        |         |         | BPWM1_CH3     | I/O  | MFP11 | BPWM1 channel 3 output/capture input.        |
|        |         |         | QEI1_A        | I    | MFP12 | Quadrature encoder 1 phase A input           |
|        |         |         | USB_D-        | A    | MFP14 | USB differential signal D-.                  |
|        |         | 99      | PA.14         | I/O  | MFP0  | General purpose digital I/O pin.             |
|        |         |         | I2S0_DI       | I    | MFP2  | I2S0 data input pin.                         |
|        |         |         | UART0_TXD     | O    | MFP3  | UART0 data transmitter output pin.           |
|        |         |         | SPI2_MISO     | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.        |
|        |         |         | I2C2_SCL      | I/O  | MFP6  | I2C2 clock pin.                              |
|        |         |         | SC2_DAT       | I/O  | MFP7  | Smart Card 2 data pin.                       |
|        |         |         | BPWM1_CH4     | I/O  | MFP11 | BPWM1 channel 4 output/capture input.        |
|        |         |         | QEI1_B        | I    | MFP12 | Quadrature encoder 1 phase B input           |
|        |         |         | USB_D+        | A    | MFP14 | USB differential signal D+.                  |
|        |         | 100     | PA.15         | I/O  | MFP0  | General purpose digital I/O pin.             |
|        |         |         | I2S0_DO       | O    | MFP2  | I2S0 data output pin.                        |
|        |         |         | UART0_RXD     | I    | MFP3  | UART0 data receiver input pin.               |
|        |         |         | SPI2_MOSI     | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.        |
|        |         |         | I2C2_SDA      | I/O  | MFP6  | I2C2 data input/output pin.                  |
|        |         |         | SC2_CLK       | O    | MFP7  | Smart Card 2 clock pin.                      |
|        |         |         | BPWM1_CH5     | I/O  | MFP11 | BPWM1 channel 5 output/capture input.        |
|        |         |         | EPWM0_SYNC_IN | I    | MFP12 | EPWM0 counter synchronous trigger input pin. |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                                                                                              |
|--------|---------|---------|-----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------|
|        |         |         | USB_OTG_ID      | I    | MFP14 | USB_ identification.                                                                                                     |
| 41     | 89      | 101     | HSUSB_VRES      | A    | MFP0  | HSUSB module reference resister                                                                                          |
| 42     | 90      | 102     | HSUSB_VDD33     | P    | MFP0  | Power supply for HSUSB VDD33                                                                                             |
| 43     | 91      | 103     | HSUSB_VBUS      | P    | MFP0  | HSUSB Power supply from USB host or HUB.                                                                                 |
| 44     | 92      | 104     | HSUSB_D-        | A    | MFP0  | HSUSB differential signal D-.                                                                                            |
| 45     | 93      | 105     | HSUSB_VSS       | P    | MFP0  | Ground pin for HSUSB.                                                                                                    |
| 46     | 94      | 106     | HSUSB_D+        | A    | MFP0  | HSUSB differential signal D+.                                                                                            |
| 47     | 95      | 107     | HSUSB_VDD12_CAP | A    | MFP0  | HSUSB Internal power regulator output 1.2V decoupling pin.<br>Note: This pin needs to be connected with a 1uF capacitor. |
| 48     | 96      | 108     | HSUSB_ID        | I    | MFP0  | HSUSB identification.                                                                                                    |
|        | 97      | 109     | PE.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |         |         | SD0_CMD         | I/O  | MFP3  | SD/SDIO0 command/response pin                                                                                            |
|        |         |         | SPIM_D2         | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.                                                                                       |
|        |         |         | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.                                                                                       |
|        |         |         | CAN1_TXD        | O    | MFP9  | CAN1 bus transmitter output.                                                                                             |
|        |         |         | QE11_INDEX      | I    | MFP11 | Quadrature encoder 1 index input                                                                                         |
|        |         |         | EPWM0_CH0       | I/O  | MFP12 | EPWM0 channel 0 output/capture input.                                                                                    |
|        |         |         | BPWM0_CH5       | I/O  | MFP13 | BPWM0 channel 5 output/capture input.                                                                                    |
|        | 98      | 110     | PE.6            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |         |         | SD0_CLK         | O    | MFP3  | SD/SDIO0 clock output pin                                                                                                |
|        |         |         | SPIM_D3         | I/O  | MFP4  | SPIM data 3 pin for Quad Mode I/O.                                                                                       |
|        |         |         | SPI3_I2SMCLK    | I/O  | MFP5  | SPI3 I2S master clock output pin                                                                                         |
|        |         |         | SC0_nCD         | I    | MFP6  | Smart Card 0 card detect pin.                                                                                            |
|        |         |         | USCI0_CTL0      | I/O  | MFP7  | USCI0 control 0 pin.                                                                                                     |
|        |         |         | UART5_RXD       | I    | MFP8  | UART5 data receiver input pin.                                                                                           |
|        |         |         | CAN1_RXD        | I    | MFP9  | CAN1 bus receiver input.                                                                                                 |
|        |         |         | QE11_A          | I    | MFP11 | Quadrature encoder 1 phase A input                                                                                       |
|        |         |         | EPWM0_CH1       | I/O  | MFP12 | EPWM0 channel 1 output/capture input.                                                                                    |
|        | 99      | 111     | BPWM0_CH4       | I/O  | MFP13 | BPWM0 channel 4 output/capture input.                                                                                    |
|        |         |         | PE.5            | I/O  | MFP0  | General purpose digital I/O pin.                                                                                         |
|        |         |         | EBI_nRD         | O    | MFP2  | EBI read enable output pin.                                                                                              |
|        |         |         | SD0_DAT3        | I/O  | MFP3  | SD/SDIO0 data line bit 3.                                                                                                |
|        |         |         | SPIM_SS         | I/O  | MFP4  | SPIM slave select pin.                                                                                                   |
|        |         |         | SPI3_SS         | I/O  | MFP5  | SPI3 slave select pin.                                                                                                   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name   | Type | MFP   | Description                           |
|--------|---------|---------|------------|------|-------|---------------------------------------|
|        |         |         | SC0_PWR    | O    | MFP6  | Smart Card 0 power pin.               |
|        |         |         | USCI0_CTL1 | I/O  | MFP7  | USCI0 control 1 pin.                  |
|        |         |         | QEI0_B     | I    | MFP11 | Quadrature encoder 0 phase B input    |
|        |         |         | EPWM0_CH2  | I/O  | MFP12 | EPWM0 channel 2 output/capture input. |
|        |         |         | BPWM0_CH3  | I/O  | MFP13 | BPWM0 channel 3 output/capture input. |
|        |         | 100     | PE.4       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         |         | EBI_nWR    | O    | MFP2  | EBI write enable output pin.          |
|        |         |         | SD0_DAT2   | I/O  | MFP3  | SD/SDIO0 data line bit 2.             |
|        |         |         | SPI0_CLK   | I/O  | MFP4  | SPI0 serial clock pin.                |
|        |         |         | SPI3_CLK   | I/O  | MFP5  | SPI3 serial clock pin.                |
|        |         |         | SC0_RST    | O    | MFP6  | Smart Card 0 reset pin.               |
|        |         |         | USCI0_DAT1 | I/O  | MFP7  | USCI0 data 1 pin.                     |
|        |         |         | QEI0_INDEX | I    | MFP11 | Quadrature encoder 0 index input      |
|        |         |         | EPWM0_CH3  | I/O  | MFP12 | EPWM0 channel 3 output/capture input. |
|        |         |         | BPWM0_CH2  | I/O  | MFP13 | BPWM0 channel 2 output/capture input. |
|        |         | 101     | PE.3       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         |         | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.        |
|        |         |         | SD0_DAT1   | I/O  | MFP3  | SD/SDIO0 data line bit 1.             |
|        |         |         | SPI0_MISO  | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin. |
|        |         |         | SPI3_MISO  | I/O  | MFP5  | SPI3 MISO (Master In, Slave Out) pin. |
|        |         |         | SC0_DAT    | I/O  | MFP6  | Smart Card 0 data pin.                |
|        |         |         | USCI0_DAT0 | I/O  | MFP7  | USCI0 data 0 pin.                     |
|        |         |         | QEI0_A     | I    | MFP11 | Quadrature encoder 0 phase A input    |
|        |         |         | EPWM0_CH4  | I/O  | MFP12 | EPWM0 channel 4 output/capture input. |
|        |         |         | BPWM0_CH1  | I/O  | MFP13 | BPWM0 channel 1 output/capture input. |
|        |         | 102     | PE.2       | I/O  | MFP0  | General purpose digital I/O pin.      |
|        |         |         | EBI_ALE    | O    | MFP2  | EBI address latch enable output pin.  |
|        |         |         | SD0_DAT0   | I/O  | MFP3  | SD/SDIO0 data line bit 0.             |
|        |         |         | SPI0_MOSI  | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin. |
|        |         |         | SPI3_MOSI  | I/O  | MFP5  | SPI3 MOSI (Master Out, Slave In) pin. |
|        |         |         | SC0_CLK    | O    | MFP6  | Smart Card 0 clock pin.               |
|        |         |         | USCI0_CLK  | I/O  | MFP7  | USCI0 clock pin.                      |
|        |         |         | QEI0_B     | I    | MFP11 | Quadrature encoder 0 phase B input    |
|        |         |         | EPWM0_CH5  | I/O  | MFP12 | EPWM0 channel 5 output/capture input. |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         |         | BPWM0_CH0       | I/O  | MFP13 | BPWM0 channel 0 output/capture input.                                           |
|        | 103     | 115     | V <sub>SS</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
|        | 104     | 116     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        | 105     | 117     | PE.1            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD10        | I/O  | MFP2  | EBI address/data bus bit 10.                                                    |
|        |         |         | QSPI0_MISO0     | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin.                                     |
|        |         |         | SC2_DAT         | I/O  | MFP4  | Smart Card 2 data pin.                                                          |
|        |         |         | I2S0_BCLK       | O    | MFP5  | I2S0 bit clock output pin.                                                      |
|        |         |         | SPI1_MISO       | I/O  | MFP6  | SPI1 MISO (Master In, Slave Out) pin.                                           |
|        |         |         | UART3_TXD       | O    | MFP7  | UART3 data transmitter output pin.                                              |
|        |         |         | I2C1_SCL        | I/O  | MFP8  | I2C1 clock pin.                                                                 |
|        |         |         | UART4_nCTS      | I    | MFP9  | UART4 clear to Send input pin.                                                  |
|        | 106     | 118     | PE.0            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |         |         | QSPI0_MOSI0     | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.                                     |
|        |         |         | SC2_CLK         | O    | MFP4  | Smart Card 2 clock pin.                                                         |
|        |         |         | I2S0_MCLK       | O    | MFP5  | I2S0 master clock output pin.                                                   |
|        |         |         | SPI1_MOSI       | I/O  | MFP6  | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|        |         |         | UART3_RXD       | I    | MFP7  | UART3 data receiver input pin.                                                  |
|        |         |         | I2C1_SDA        | I/O  | MFP8  | I2C1 data input/output pin.                                                     |
|        |         |         | UART4_nRTS      | O    | MFP9  | UART4 request to Send output pin.                                               |
|        | 107     | 119     | PH.8            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD12        | I/O  | MFP2  | EBI address/data bus bit 12.                                                    |
|        |         |         | QSPI0_CLK       | I/O  | MFP3  | Quad SPI0 serial clock pin.                                                     |
|        |         |         | SC2_PWR         | O    | MFP4  | Smart Card 2 power pin.                                                         |
|        |         |         | I2S0_DI         | I    | MFP5  | I2S0 data input pin.                                                            |
|        |         |         | SPI1_CLK        | I/O  | MFP6  | SPI1 serial clock pin.                                                          |
|        |         |         | UART3_nRTS      | O    | MFP7  | UART3 request to Send output pin.                                               |
|        |         |         | I2C1_SMBAL      | O    | MFP8  | I2C1 SMBus SMBALTER pin                                                         |
|        |         |         | I2C2_SCL        | I/O  | MFP9  | I2C2 clock pin.                                                                 |
|        |         |         | UART1_TXD       | O    | MFP10 | UART1 data transmitter output pin.                                              |
|        | 108     | 120     | PH.9            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD13        | I/O  | MFP2  | EBI address/data bus bit 13.                                                    |

| 64 Pin | 128 Pin | 144 Pin | Pin Name     | Type | MFP   | Description                                 |
|--------|---------|---------|--------------|------|-------|---------------------------------------------|
|        |         |         | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                 |
|        |         |         | SC2_RST      | O    | MFP4  | Smart Card 2 reset pin.                     |
|        |         |         | I2S0_DO      | O    | MFP5  | I2S0 data output pin.                       |
|        |         |         | SPI1_SS      | I/O  | MFP6  | SPI1 slave select pin.                      |
|        |         |         | UART3_nCTS   | I    | MFP7  | UART3 clear to Send input pin.              |
|        |         |         | I2C1_SMBSUS  | O    | MFP8  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin)   |
|        |         |         | I2C2_SDA     | I/O  | MFP9  | I2C2 data input/output pin.                 |
|        |         |         | UART1_RXD    | I    | MFP10 | UART1 data receiver input pin.              |
|        | 109     | 121     | PH.10        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_AD14     | I/O  | MFP2  | EBI address/data bus bit 14.                |
|        |         |         | QSPI0_MISO1  | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|        |         |         | SC2_nCD      | I    | MFP4  | Smart Card 2 card detect pin.               |
|        |         |         | I2S0_LRCK    | O    | MFP5  | I2S0 left right channel clock output pin.   |
|        |         |         | SPI1_I2SMCLK | I/O  | MFP6  | SPI1 I2S master clock output pin            |
|        |         |         | UART4_TXD    | O    | MFP7  | UART4 data transmitter output pin.          |
|        |         |         | UART0_TXD    | O    | MFP8  | UART0 data transmitter output pin.          |
|        | 110     | 122     | PH.11        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_AD15     | I/O  | MFP2  | EBI address/data bus bit 15.                |
|        |         |         | QSPI0_MOSI1  | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|        |         |         | UART4_RXD    | I    | MFP7  | UART4 data receiver input pin.              |
|        |         |         | UART0_RXD    | I    | MFP8  | UART0 data receiver input pin.              |
|        |         |         | EPWM0_CH5    | I/O  | MFP11 | EPWM0 channel 5 output/capture input.       |
|        | 111     | 123     | PD.14        | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.               |
|        |         |         | SPI3_I2SMCLK | I/O  | MFP3  | SPI3 I2S master clock output pin            |
|        |         |         | SC1_nCD      | I    | MFP4  | Smart Card 1 card detect pin.               |
|        |         |         | EPWM0_CH4    | I/O  | MFP11 | EPWM0 channel 4 output/capture input.       |
|        |         | 124     | PG.5         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.               |
|        |         |         | SPI3_SS      | I/O  | MFP3  | SPI3 slave select pin.                      |
|        |         |         | SC1_PWR      | O    | MFP4  | Smart Card 1 power pin.                     |
|        |         |         | EPWM0_CH3    | I/O  | MFP11 | EPWM0 channel 3 output/capture input.       |
|        |         | 125     | PG.6         | I/O  | MFP0  | General purpose digital I/O pin.            |
|        |         |         | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.               |

| 64 Pin | 128 Pin | 144 Pin | Pin Name        | Type | MFP   | Description                                                                     |
|--------|---------|---------|-----------------|------|-------|---------------------------------------------------------------------------------|
|        |         |         | SPI3_CLK        | I/O  | MFP3  | SPI3 serial clock pin.                                                          |
|        |         |         | SC1_RST         | O    | MFP4  | Smart Card 1 reset pin.                                                         |
|        |         |         | EPWM0_CH2       | I/O  | MFP11 | EPWM0 channel 2 output/capture input.                                           |
|        |         | 126     | PG.7            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_nWRL        | O    | MFP2  | EBI low byte write enable output pin.                                           |
|        |         |         | SPI3_MISO       | I/O  | MFP3  | SPI3 MISO (Master In, Slave Out) pin.                                           |
|        |         |         | SC1_DAT         | I/O  | MFP4  | Smart Card 1 data pin.                                                          |
|        |         |         | EPWM0_CH1       | I/O  | MFP11 | EPWM0 channel 1 output/capture input.                                           |
|        |         | 127     | PG.8            | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_nWRH        | O    | MFP2  | EBI high byte write enable output pin                                           |
|        |         |         | SPI3_MOSI       | I/O  | MFP3  | SPI3 MOSI (Master Out, Slave In) pin.                                           |
|        |         |         | SC1_CLK         | O    | MFP4  | Smart Card 1 clock pin.                                                         |
|        |         |         | EPWM0_CH0       | I/O  | MFP11 | EPWM0 channel 0 output/capture input.                                           |
| 49     | 112     | 128     | V <sub>ss</sub> | P    | MFP0  | Ground pin for digital circuit.                                                 |
| 50     | 113     | 129     | LDO_CAP         | A    | MFP0  | LDO output pin.                                                                 |
| 51     | 114     | 130     | V <sub>DD</sub> | P    | MFP0  | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|        |         | 131     | PC.14           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EBI_AD11        | I/O  | MFP2  | EBI address/data bus bit 11.                                                    |
|        |         |         | SC1_nCD         | I    | MFP3  | Smart Card 1 card detect pin.                                                   |
|        |         |         | SPI0_I2SMCLK    | I/O  | MFP4  | SPI0 I2S master clock output pin                                                |
|        |         |         | USCI0_CTL0      | I/O  | MFP5  | USCI0 control 0 pin.                                                            |
|        |         |         | QSPI0_CLK       | I/O  | MFP6  | Quad SPI0 serial clock pin.                                                     |
|        |         |         | EPWM0_SYNC_IN   | I    | MFP11 | EPWM0 counter synchronous trigger input pin.                                    |
|        |         |         | TM1             | I/O  | MFP13 | Timer1 event counter input/toggle output pin.                                   |
|        |         |         | USB_VBUS_ST     | I    | MFP14 | USB external VBUS regulator status pin.                                         |
|        |         | 132     | HSUSB_VBUS_ST   | I    | MFP15 | HSUSB external VBUS regulator status pin.                                       |
|        |         |         | PB.15           | I/O  | MFP0  | General purpose digital I/O pin.                                                |
|        |         |         | EADC0_CH15      | A    | MFP1  | EADC0 channel 15 analog input.                                                  |
|        |         |         | EBI_AD12        | I/O  | MFP2  | EBI address/data bus bit 12.                                                    |
|        |         |         | SC1_PWR         | O    | MFP3  | Smart Card 1 power pin.                                                         |
|        |         |         | SPI0_SS         | I/O  | MFP4  | SPI0 slave select pin.                                                          |
|        |         |         | USCI0_CTL1      | I/O  | MFP5  | USCI0 control 1 pin.                                                            |
|        |         |         | UART0_nCTS      | I    | MFP6  | UART0 clear to Send input pin.                                                  |

| 64 Pin | 128 Pin | 144 Pin | Pin Name      | Type | MFP   | Description                                      |
|--------|---------|---------|---------------|------|-------|--------------------------------------------------|
|        |         |         | UART3_TXD     | O    | MFP7  | UART3 data transmitter output pin.               |
|        |         |         | I2C2_SMBAL    | O    | MFP8  | I2C2 SMBus SMBALTER pin                          |
|        |         |         | EPWM1_CH0     | I/O  | MFP11 | EPWM1 channel 0 output/capture input.            |
|        |         |         | TM0_EXT       | I/O  | MFP13 | Timer0 external capture input/toggle output pin. |
|        |         |         | USB_VBUS_EN   | O    | MFP14 | USB external VBUS regulator enable pin.          |
|        |         |         | HSUSB_VBUS_EN | O    | MFP15 | HSUSB external VBUS regulator enable pin.        |
|        |         |         | PB.14         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | EADC0_CH14    | A    | MFP1  | EADC0 channel 14 analog input.                   |
|        |         |         | EBI_AD13      | I/O  | MFP2  | EBI address/data bus bit 13.                     |
|        |         |         | SC1_RST       | O    | MFP3  | Smart Card 1 reset pin.                          |
|        |         |         | SPI0_CLK      | I/O  | MFP4  | SPI0 serial clock pin.                           |
|        |         |         | USCI0_DAT1    | I/O  | MFP5  | USCI0 data 1 pin.                                |
|        |         |         | UART0_nRTS    | O    | MFP6  | UART0 request to Send output pin.                |
|        |         |         | UART3_RXD     | I    | MFP7  | UART3 data receiver input pin.                   |
|        |         |         | I2C2_SMBSUS   | O    | MFP8  | I2C2 SMBus SMBSUS pin (PMBus CONTROL pin)        |
|        |         |         | EPWM1_CH1     | I/O  | MFP11 | EPWM1 channel 1 output/capture input.            |
|        |         |         | TM1_EXT       | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|        |         |         | CLKO          | O    | MFP14 | Clock Out                                        |
|        |         |         | PB.13         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | EADC0_CH13    | A    | MFP1  | EADC0 channel 13 analog input.                   |
|        |         |         | DAC1_OUT      | A    | MFP1  | DAC1 channel analog output.                      |
|        |         |         | ACMP0_P3      | A    | MFP1  | Analog comparator 0 positive input 3 pin.        |
|        |         |         | ACMP1_P3      | A    | MFP1  | Analog comparator 1 positive input 3 pin.        |
|        |         |         | EBI_AD14      | I/O  | MFP2  | EBI address/data bus bit 14.                     |
|        |         |         | SC1_DAT       | I/O  | MFP3  | Smart Card 1 data pin.                           |
|        |         |         | SPI0_MISO     | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.            |
|        |         |         | USCI0_DAT0    | I/O  | MFP5  | USCI0 data 0 pin.                                |
|        |         |         | UART0_TXD     | O    | MFP6  | UART0 data transmitter output pin.               |
|        |         |         | UART3_nRTS    | O    | MFP7  | UART3 request to Send output pin.                |
|        |         |         | I2C2_SCL      | I/O  | MFP8  | I2C2 clock pin.                                  |
|        |         |         | EPWM1_CH2     | I/O  | MFP11 | EPWM1 channel 2 output/capture input.            |
|        |         |         | TM2_EXT       | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|        |         |         | PB.12         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|        |         |         | EADC0_CH12    | A    | MFP1  | EADC0 channel 12 analog input.                   |

| 64 Pin | 128 Pin | 144 Pin | Pin Name         | Type | MFP   | Description                                                                                |
|--------|---------|---------|------------------|------|-------|--------------------------------------------------------------------------------------------|
|        |         |         | DAC0_OUT         | A    | MFP1  | DAC0 channel analog output.                                                                |
|        |         |         | ACMP0_P2         | A    | MFP1  | Analog comparator 0 positive input 2 pin.                                                  |
|        |         |         | ACMP1_P2         | A    | MFP1  | Analog comparator 1 positive input 2 pin.                                                  |
|        |         |         | EBI_AD15         | I/O  | MFP2  | EBI address/data bus bit 15.                                                               |
|        |         |         | SC1_CLK          | O    | MFP3  | Smart Card 1 clock pin.                                                                    |
|        |         |         | SPI0_MOSI        | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.                                                      |
|        |         |         | USCI0_CLK        | I/O  | MFP5  | USCI0 clock pin.                                                                           |
|        |         |         | UART0_RXD        | I    | MFP6  | UART0 data receiver input pin.                                                             |
|        |         |         | UART3_nCTS       | I    | MFP7  | UART3 clear to Send input pin.                                                             |
|        |         |         | I2C2_SDA         | I/O  | MFP8  | I2C2 data input/output pin.                                                                |
|        |         |         | SD0_nCD          | I    | MFP9  | SD/SDIO0 card detect input pin                                                             |
|        |         |         | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                                                      |
|        |         |         | TM3_EXT          | I/O  | MFP13 | Timer3 external capture input/toggle output pin.                                           |
| 57     | 120     | 136     | AV <sub>DD</sub> | P    | MFP0  | Power supply for internal analog circuit.                                                  |
| 58     | 121     | 137     | V <sub>REF</sub> | A    | MFP0  | ADC reference voltage input.<br>Note: This pin needs to be connected with a 1uF capacitor. |
| 59     | 122     | 138     | AV <sub>SS</sub> | P    | MFP0  | Ground pin for analog circuit.                                                             |
|        |         |         | PB.11            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |         |         | EADC0_CH11       | A    | MFP1  | EADC0 channel 11 analog input.                                                             |
|        |         |         | EBI_ADR16        | O    | MFP2  | EBI address bus bit 16.                                                                    |
|        |         |         | EMAC_RMII_MDC    | O    | MFP3  | EMAC RMII PHY Management Clock output pin.                                                 |
|        |         |         | UART0_nCTS       | I    | MFP5  | UART0 clear to Send input pin.                                                             |
|        |         |         | UART4_TXD        | O    | MFP6  | UART4 data transmitter output pin.                                                         |
|        |         |         | I2C1_SCL         | I/O  | MFP7  | I2C1 clock pin.                                                                            |
|        |         |         | CAN0_TXD         | O    | MFP8  | CAN0 bus transmitter output.                                                               |
|        |         |         | SPI0_I2SMCLK     | I/O  | MFP9  | SPI0 I2S master clock output pin                                                           |
|        |         |         | BPWM1_CH0        | I/O  | MFP10 | BPWM1 channel 0 output/capture input.                                                      |
|        |         |         | SPI3_CLK         | I/O  | MFP11 | SPI3 serial clock pin.                                                                     |
|        |         |         | HSUSB_VBUS_ST    | I    | MFP14 | HSUSB external VBUS regulator status pin.                                                  |
|        |         |         | PB.10            | I/O  | MFP0  | General purpose digital I/O pin.                                                           |
|        |         |         | EADC0_CH10       | A    | MFP1  | EADC0 channel 10 analog input.                                                             |
|        |         |         | EBI_ADR17        | O    | MFP2  | EBI address bus bit 17.                                                                    |
|        |         |         | EMAC_RMII_MDIO   | I/O  | MFP3  | EMAC RMII PHY Management Data pin.                                                         |
|        |         |         | USCI1_CTL0       | I/O  | MFP4  | USCI1 control 0 pin.                                                                       |

| 64 Pin | 128 Pin | 144 Pin | Pin Name       | Type | MFP   | Description                               |
|--------|---------|---------|----------------|------|-------|-------------------------------------------|
|        |         |         | UART0_nRTS     | O    | MFP5  | UART0 request to Send output pin.         |
|        |         |         | UART4_RXD      | I    | MFP6  | UART4 data receiver input pin.            |
|        |         |         | I2C1_SDA       | I/O  | MFP7  | I2C1 data input/output pin.               |
|        |         |         | CAN0_RXD       | I    | MFP8  | CAN0 bus receiver input.                  |
|        |         |         | BPWM1_CH1      | I/O  | MFP10 | BPWM1 channel 1 output/capture input.     |
|        |         |         | SPI3_SS        | I/O  | MFP11 | SPI3 slave select pin.                    |
|        |         |         | HSUSB_VBUS_EN  | O    | MFP14 | HSUSB external VBUS regulator enable pin. |
|        |         |         | PB.9           | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         |         | EADC0_CH9      | A    | MFP1  | EADC0 channel 9 analog input.             |
|        |         |         | EBI_ADR18      | O    | MFP2  | EBI address bus bit 18.                   |
|        |         |         | EMAC_RMII_TXD0 | O    | MFP3  | EMAC RMII Transmit Data bus bit 0.        |
|        |         |         | USCI1_CTL1     | I/O  | MFP4  | USCI1 control 1 pin.                      |
|        |         |         | UART0_TXD      | O    | MFP5  | UART0 data transmitter output pin.        |
|        |         |         | UART1_nCTS     | I    | MFP6  | UART1 clear to Send input pin.            |
|        |         |         | I2C1_SMBAL     | O    | MFP7  | I2C1 SMBus SMBALTER pin                   |
|        |         |         | BPWM1_CH2      | I/O  | MFP10 | BPWM1 channel 2 output/capture input.     |
|        |         |         | SPI3_MISO      | I/O  | MFP11 | SPI3 MISO (Master In, Slave Out) pin.     |
|        |         |         | INT7           | I    | MFP13 | External interrupt 7 input pin.           |
|        |         |         | PB.8           | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         |         | EADC0_CH8      | A    | MFP1  | EADC0 channel 8 analog input.             |
|        |         |         | EBI_ADR19      | O    | MFP2  | EBI address bus bit 19.                   |
|        |         |         | EMAC_RMII_TXD1 | O    | MFP3  | EMAC RMII Transmit Data bus bit 1.        |
|        |         |         | USCI1_CLK      | I/O  | MFP4  | USCI1 clock pin.                          |
|        |         |         | UART0_RXD      | I    | MFP5  | UART0 data receiver input pin.            |
|        |         |         | UART1_nRTS     | O    | MFP6  | UART1 request to Send output pin.         |
|        |         |         | I2C1_SMBSUS    | O    | MFP7  | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|        |         |         | BPWM1_CH3      | I/O  | MFP10 | BPWM1 channel 3 output/capture input.     |
|        |         |         | SPI3_MOSI      | I/O  | MFP11 | SPI3 MOSI (Master Out, Slave In) pin.     |
|        |         |         | INT6           | I    | MFP13 | External interrupt 6 input pin.           |
|        |         |         | PB.7           | I/O  | MFP0  | General purpose digital I/O pin.          |
|        |         |         | EADC0_CH7      | A    | MFP1  | EADC0 channel 7 analog input.             |
|        |         |         | EBI_nWRL       | O    | MFP2  | EBI low byte write enable output pin.     |
|        |         |         | EMAC_RMII_TXEN | O    | MFP3  | EMAC RMII Transmit Enable output pin.     |
|        |         |         | USCI1_DAT0     | I/O  | MFP4  | USCI1 data 0 pin.                         |

| 64 Pin | 128 Pin | 144 Pin | Pin Name     | Type | MFP   | Description                             |
|--------|---------|---------|--------------|------|-------|-----------------------------------------|
|        |         |         | CAN1_TXD     | O    | MFP5  | CAN1 bus transmitter output.            |
|        |         |         | UART1_TXD    | O    | MFP6  | UART1 data transmitter output pin.      |
|        |         |         | SD1_CMD      | I/O  | MFP7  | SD/SDIO1 command/response pin           |
|        |         |         | EBI_nCS0     | O    | MFP8  | EBI chip select 0 output pin.           |
|        |         |         | BPWM1_CH4    | I/O  | MFP10 | BPWM1 channel 4 output/capture input.   |
|        |         |         | EPWM1_BRAKE0 | I    | MFP11 | EPWM1 Brake 0 input pin.                |
|        |         |         | EPWM1_CH4    | I/O  | MFP12 | EPWM1 channel 4 output/capture input.   |
|        |         |         | INT5         | I    | MFP13 | External interrupt 5 input pin.         |
|        |         |         | USB_VBUS_ST  | I    | MFP14 | USB external VBUS regulator status pin. |
|        |         |         | ACMP0_O      | O    | MFP15 | Analog comparator 0 output pin.         |
|        |         | 128     | PB.6         | I/O  | MFP0  | General purpose digital I/O pin.        |
|        |         |         | EADC0_CH6    | A    | MFP1  | EADC0 channel 6 analog input.           |
|        |         |         | EBI_nWRH     | O    | MFP2  | EBI high byte write enable output pin   |
|        |         |         | EMAC_PPS     | O    | MFP3  | EMAC Pulse Per Second output pin.       |
|        |         |         | USCI1_DAT1   | I/O  | MFP4  | USCI1 data 1 pin.                       |
|        |         |         | CAN1_RXD     | I    | MFP5  | CAN1 bus receiver input.                |
|        |         |         | UART1_RXD    | I    | MFP6  | UART1 data receiver input pin.          |
|        |         |         | SD1_CLK      | O    | MFP7  | SD/SDIO1 clock output pin               |
|        |         |         | EBI_nCS1     | O    | MFP8  | EBI chip select 1 output pin.           |
|        |         |         | BPWM1_CH5    | I/O  | MFP10 | BPWM1 channel 5 output/capture input.   |
|        |         |         | EPWM1_BRAKE1 | I    | MFP11 | EPWM1 Brake 1 input pin.                |
|        |         |         | EPWM1_CH5    | I/O  | MFP12 | EPWM1 channel 5 output/capture input.   |
|        |         |         | INT4         | I    | MFP13 | External interrupt 4 input pin.         |
|        |         |         | USB_VBUS_EN  | O    | MFP14 | USB external VBUS regulator enable pin. |
|        |         |         | ACMP1_O      | O    | MFP15 | Analog comparator 1 output pin.         |

## 4.2.7 M480 Multi-function Summary Table

| Group | Pin Name   | GPIO  | MFP   | Type | Description                                |
|-------|------------|-------|-------|------|--------------------------------------------|
| ACMP0 | ACMP0_N    | PB.3  | MFP1  | A    | Analog comparator 0 negative input pin.    |
|       | ACMP0_O    | PC.12 | MFP14 | O    | Analog comparator 0 output pin.            |
|       |            | PC.1  | MFP14 | O    |                                            |
|       |            | PB.7  | MFP15 | O    |                                            |
|       | ACMP0_P0   | PA.11 | MFP1  | A    | Analog comparator 0 positive input 0 pin.  |
|       | ACMP0_P1   | PB.2  | MFP1  | A    | Analog comparator 0 positive input 1 pin.  |
|       | ACMP0_P2   | PB.12 | MFP1  | A    | Analog comparator 0 positive input 2 pin.  |
|       | ACMP0_P3   | PB.13 | MFP1  | A    | Analog comparator 0 positive input 3 pin.  |
|       | ACMP0_WLAT | PA.7  | MFP13 | I    | Analog comparator 0 window latch input pin |
| ACMP1 | ACMP1_N    | PB.5  | MFP1  | A    | Analog comparator 1 negative input pin.    |
|       | ACMP1_O    | PC.11 | MFP14 | O    | Analog comparator 1 output pin.            |
|       |            | PC.0  | MFP14 | O    |                                            |
|       |            | PB.6  | MFP15 | O    |                                            |
|       | ACMP1_P0   | PA.10 | MFP1  | A    | Analog comparator 1 positive input 0 pin.  |
|       | ACMP1_P1   | PB.4  | MFP1  | A    | Analog comparator 1 positive input 1 pin.  |
|       | ACMP1_P2   | PB.12 | MFP1  | A    | Analog comparator 1 positive input 2 pin.  |
|       | ACMP1_P3   | PB.13 | MFP1  | A    | Analog comparator 1 positive input 3 pin.  |
|       | ACMP1_WLAT | PA.6  | MFP13 | I    | Analog comparator 1 window latch input pin |
| BPWM0 | BPWM0_CH0  | PA.11 | MFP9  | I/O  | BPWM0 channel 0 output/capture input.      |
|       |            | PA.0  | MFP12 | I/O  |                                            |
|       |            | PG.14 | MFP12 | I/O  |                                            |
|       |            | PE.2  | MFP13 | I/O  |                                            |
|       | BPWM0_CH1  | PA.10 | MFP9  | I/O  | BPWM0 channel 1 output/capture input.      |
|       |            | PA.1  | MFP12 | I/O  |                                            |
|       |            | PG.13 | MFP12 | I/O  |                                            |
|       |            | PE.3  | MFP13 | I/O  |                                            |
|       | BPWM0_CH2  | PA.9  | MFP9  | I/O  | BPWM0 channel 2 output/capture input.      |
|       |            | PA.2  | MFP12 | I/O  |                                            |
|       |            | PG.12 | MFP12 | I/O  |                                            |
|       |            | PE.4  | MFP13 | I/O  |                                            |
|       | BPWM0_CH3  | PA.8  | MFP9  | I/O  | BPWM0 channel 3 output/capture input.      |
|       |            | PA.3  | MFP12 | I/O  |                                            |
|       |            | PG.11 | MFP12 | I/O  |                                            |

| Group | Pin Name  | GPIO  | MFP   | Type | Description                           |
|-------|-----------|-------|-------|------|---------------------------------------|
| BPWM1 | BPWM0_CH4 | PE.5  | MFP13 | I/O  | BPWM0 channel 4 output/capture input. |
|       |           | PC.13 | MFP9  | I/O  |                                       |
|       |           | PF.5  | MFP8  | I/O  |                                       |
|       |           | PA.4  | MFP12 | I/O  |                                       |
|       |           | PG.10 | MFP12 | I/O  |                                       |
|       | BPWM0_CH5 | PE.6  | MFP13 | I/O  | BPWM0 channel 5 output/capture input. |
|       |           | PD.12 | MFP9  | I/O  |                                       |
|       |           | PF.4  | MFP8  | I/O  |                                       |
|       |           | PA.5  | MFP12 | I/O  |                                       |
|       |           | PG.9  | MFP12 | I/O  |                                       |
|       | BPWM1_CH0 | PE.7  | MFP13 | I/O  | BPWM1 channel 0 output/capture input. |
|       |           | PF.3  | MFP11 | I/O  |                                       |
|       |           | PC.7  | MFP12 | I/O  |                                       |
|       |           | PF.0  | MFP12 | I/O  |                                       |
|       | BPWM1_CH1 | PB.11 | MFP10 | I/O  | BPWM1 channel 1 output/capture input. |
|       |           | PF.2  | MFP11 | I/O  |                                       |
|       |           | PC.6  | MFP12 | I/O  |                                       |
|       |           | PF.1  | MFP12 | I/O  |                                       |
|       | BPWM1_CH2 | PB.10 | MFP10 | I/O  | BPWM1 channel 2 output/capture input. |
|       |           | PA.7  | MFP12 | I/O  |                                       |
|       |           | PA.12 | MFP11 | I/O  |                                       |
|       | BPWM1_CH3 | PB.9  | MFP10 | I/O  | BPWM1 channel 3 output/capture input. |
|       |           | PA.6  | MFP12 | I/O  |                                       |
|       |           | PA.13 | MFP11 | I/O  |                                       |
|       | BPWM1_CH4 | PB.8  | MFP10 | I/O  | BPWM1 channel 4 output/capture input. |
|       |           | PC.8  | MFP12 | I/O  |                                       |
|       |           | PA.14 | MFP11 | I/O  |                                       |
|       | BPWM1_CH5 | PB.7  | MFP10 | I/O  | BPWM1 channel 5 output/capture input. |
|       |           | PE.13 | MFP12 | I/O  |                                       |
|       |           | PA.15 | MFP11 | I/O  |                                       |
|       | CAN0      | PB.6  | MFP10 | I/O  | CAN0 bus receiver input.              |
|       |           | PD.10 | MFP4  | I    |                                       |
|       |           | PA.4  | MFP10 | I    |                                       |
|       |           | PE.15 | MFP4  | I    |                                       |

| Group | Pin Name  | GPIO  | MFP   | Type | Description                   |
|-------|-----------|-------|-------|------|-------------------------------|
| CAN0  |           | PC.4  | MFP10 | I    | CAN0 bus transmitter output.  |
|       |           | PA.13 | MFP6  | I    |                               |
|       |           | PB.10 | MFP8  | I    |                               |
|       | CAN0_TXD  | PD.11 | MFP4  | O    |                               |
|       |           | PA.5  | MFP10 | O    |                               |
|       |           | PE.14 | MFP4  | O    |                               |
|       |           | PC.5  | MFP10 | O    |                               |
|       |           | PA.12 | MFP6  | O    |                               |
|       |           | PB.11 | MFP8  | O    |                               |
|       | CAN1_RXD  | PC.9  | MFP9  | I    |                               |
|       |           | PD.12 | MFP5  | I    |                               |
|       |           | PG.1  | MFP7  | I    |                               |
|       |           | PC.2  | MFP10 | I    |                               |
|       |           | PE.6  | MFP9  | I    |                               |
|       |           | PB.6  | MFP5  | I    |                               |
| CAN1  | CAN1_TXD  | PC.10 | MFP9  | O    | CAN1 bus transmitter output.  |
|       |           | PC.13 | MFP5  | O    |                               |
|       |           | PG.0  | MFP7  | O    |                               |
|       |           | PC.3  | MFP10 | O    |                               |
|       |           | PE.7  | MFP9  | O    |                               |
|       |           | PB.7  | MFP5  | O    |                               |
|       | CLKO      | PC.13 | MFP13 | O    | Clock Out                     |
|       |           | PD.12 | MFP13 | O    |                               |
|       |           | PG.15 | MFP14 | O    |                               |
|       |           | PB.14 | MFP14 | O    |                               |
| DAC0  | DAC0_OUT  | PB.12 | MFP1  | A    | DAC0 channel analog output.   |
|       | DAC0_ST   | PA.10 | MFP14 | I    | DAC0 external trigger input.  |
|       |           | PA.0  | MFP15 | I    |                               |
| DAC1  | DAC1_OUT  | PB.13 | MFP1  | A    | DAC1 channel analog output.   |
|       | DAC1_ST   | PA.11 | MFP14 | I    | DAC1 external trigger input.  |
|       |           | PA.1  | MFP15 | I    |                               |
| EADC0 | EADC0_CH0 | PB.0  | MFP1  | A    | EADC0 channel 0 analog input. |
|       | EADC0_CH1 | PB.1  | MFP1  | A    | EADC0 channel 1 analog input. |
|       | EADC0_CH2 | PB.2  | MFP1  | A    | EADC0 channel 2 analog input. |

| Group | Pin Name   | GPIO  | MFP   | Type | Description                    |
|-------|------------|-------|-------|------|--------------------------------|
| EADC0 | EADC0_CH3  | PB.3  | MFP1  | A    | EADC0 channel 3 analog input.  |
|       | EADC0_CH4  | PB.4  | MFP1  | A    | EADC0 channel 4 analog input.  |
|       | EADC0_CH5  | PB.5  | MFP1  | A    | EADC0 channel 5 analog input.  |
|       | EADC0_CH6  | PB.6  | MFP1  | A    | EADC0 channel 6 analog input.  |
|       | EADC0_CH7  | PB.7  | MFP1  | A    | EADC0 channel 7 analog input.  |
|       | EADC0_CH8  | PB.8  | MFP1  | A    | EADC0 channel 8 analog input.  |
|       | EADC0_CH9  | PB.9  | MFP1  | A    | EADC0 channel 9 analog input.  |
|       | EADC0_CH10 | PB.10 | MFP1  | A    | EADC0 channel 10 analog input. |
|       | EADC0_CH11 | PB.11 | MFP1  | A    | EADC0 channel 11 analog input. |
|       | EADC0_CH12 | PB.12 | MFP1  | A    | EADC0 channel 12 analog input. |
|       | EADC0_CH13 | PB.13 | MFP1  | A    | EADC0 channel 13 analog input. |
|       | EADC0_CH14 | PB.14 | MFP1  | A    | EADC0 channel 14 analog input. |
|       | EADC0_CH15 | PB.15 | MFP1  | A    | EADC0 channel 15 analog input. |
|       | EADC0_ST   | PC.13 | MFP14 | I    | EADC0 external trigger input.  |
|       |            | PD.12 | MFP14 | I    |                                |
|       |            | PF.5  | MFP11 | I    |                                |
|       |            | PG.15 | MFP15 | I    |                                |
| EBI   | EBI_AD0    | PC.0  | MFP2  | I/O  | EBI address/data bus bit 0.    |
|       |            | PG.9  | MFP2  | I/O  |                                |
|       | EBI_AD1    | PC.1  | MFP2  | I/O  | EBI address/data bus bit 1.    |
|       |            | PG.10 | MFP2  | I/O  |                                |
|       | EBI_AD2    | PC.2  | MFP2  | I/O  | EBI address/data bus bit 2.    |
|       |            | PG.11 | MFP2  | I/O  |                                |
|       | EBI_AD3    | PC.3  | MFP2  | I/O  | EBI address/data bus bit 3.    |
|       |            | PG.12 | MFP2  | I/O  |                                |
|       | EBI_AD4    | PC.4  | MFP2  | I/O  | EBI address/data bus bit 4.    |
|       |            | PG.13 | MFP2  | I/O  |                                |
|       | EBI_AD5    | PC.5  | MFP2  | I/O  | EBI address/data bus bit 5.    |
|       |            | PG.14 | MFP2  | I/O  |                                |
|       | EBI_AD6    | PA.6  | MFP2  | I/O  | EBI address/data bus bit 6.    |
|       |            | PD.8  | MFP2  | I/O  |                                |
|       | EBI_AD7    | PA.7  | MFP2  | I/O  | EBI address/data bus bit 7.    |
|       |            | PD.9  | MFP2  | I/O  |                                |
|       | EBI_AD8    | PC.6  | MFP2  | I/O  | EBI address/data bus bit 8.    |

| Group    | Pin Name | GPIO  | MFP  | Type | Description                  |
|----------|----------|-------|------|------|------------------------------|
| EBI_AD9  |          | PE.14 | MFP2 | I/O  |                              |
|          |          | PC.7  | MFP2 | I/O  | EBI address/data bus bit 9.  |
|          |          | PE.15 | MFP2 | I/O  |                              |
| EBI_AD10 |          | PD.3  | MFP2 | I/O  | EBI address/data bus bit 10. |
|          |          | PD.13 | MFP2 | I/O  |                              |
|          |          | PE.1  | MFP2 | I/O  |                              |
| EBI_AD11 |          | PD.2  | MFP2 | I/O  | EBI address/data bus bit 11. |
|          |          | PE.0  | MFP2 | I/O  |                              |
|          |          | PC.14 | MFP2 | I/O  |                              |
| EBI_AD12 |          | PD.1  | MFP2 | I/O  | EBI address/data bus bit 12. |
|          |          | PH.8  | MFP2 | I/O  |                              |
|          |          | PB.15 | MFP2 | I/O  |                              |
| EBI_AD13 |          | PD.0  | MFP2 | I/O  | EBI address/data bus bit 13. |
|          |          | PH.9  | MFP2 | I/O  |                              |
|          |          | PB.14 | MFP2 | I/O  |                              |
| EBI_AD14 |          | PH.10 | MFP2 | I/O  | EBI address/data bus bit 14. |
|          |          | PB.13 | MFP2 | I/O  |                              |
|          |          | PH.11 | MFP2 | I/O  |                              |
| EBI_AD15 |          | PB.12 | MFP2 | I/O  | EBI address/data bus bit 15. |
|          |          | PB.5  | MFP2 | O    |                              |
| EBI_ADR0 |          | PH.7  | MFP2 | O    | EBI address bus bit 0.       |
|          |          | PB.4  | MFP2 | O    |                              |
| EBI_ADR1 |          | PH.6  | MFP2 | O    | EBI address bus bit 1.       |
|          |          | PB.3  | MFP2 | O    |                              |
| EBI_ADR2 |          | PH.5  | MFP2 | O    | EBI address bus bit 2.       |
|          |          | PB.2  | MFP2 | O    |                              |
| EBI_ADR3 |          | PH.4  | MFP2 | O    | EBI address bus bit 3.       |
|          |          | PC.12 | MFP2 | O    |                              |
| EBI_ADR4 |          | PH.3  | MFP2 | O    | EBI address bus bit 4.       |
|          |          | PC.11 | MFP2 | O    |                              |
| EBI_ADR5 |          | PH.2  | MFP2 | O    | EBI address bus bit 5.       |
|          |          | PC.10 | MFP2 | O    |                              |
| EBI_ADR6 |          | PH.1  | MFP2 | O    | EBI address bus bit 6.       |
|          |          | PC.9  | MFP2 | O    |                              |
| EBI_ADR7 |          |       |      |      | EBI address bus bit 7.       |

| Group     | Pin Name | GPIO | MFP  | Type | Description                          |
|-----------|----------|------|------|------|--------------------------------------|
|           |          | PH.0 | MFP2 | O    |                                      |
| EBI_ADR8  | PB.1     | MFP2 | O    |      | EBI address bus bit 8.               |
|           | PG.0     | MFP2 | O    |      |                                      |
| EBI_ADR9  | PB.0     | MFP2 | O    |      | EBI address bus bit 9.               |
|           | PG.1     | MFP2 | O    |      |                                      |
| EBI_ADR10 | PC.13    | MFP2 | O    |      | EBI address bus bit 10.              |
|           | PE.8     | MFP2 | O    |      |                                      |
| EBI_ADR11 | PG.2     | MFP2 | O    |      | EBI address bus bit 11.              |
|           | PE.9     | MFP2 | O    |      |                                      |
| EBI_ADR12 | PG.3     | MFP2 | O    |      | EBI address bus bit 12.              |
|           | PE.10    | MFP2 | O    |      |                                      |
| EBI_ADR13 | PG.4     | MFP2 | O    |      | EBI address bus bit 13.              |
|           | PE.11    | MFP2 | O    |      |                                      |
| EBI_ADR14 | PF.11    | MFP2 | O    |      | EBI address bus bit 14.              |
|           | PE.12    | MFP2 | O    |      |                                      |
| EBI_ADR15 | PF.10    | MFP2 | O    |      | EBI address bus bit 15.              |
|           | PE.13    | MFP2 | O    |      |                                      |
| EBI_ADR16 | PF.9     | MFP2 | O    |      | EBI address bus bit 16.              |
|           | PC.8     | MFP2 | O    |      |                                      |
|           | PB.11    | MFP2 | O    |      |                                      |
| EBI_ADR17 | PF.8     | MFP2 | O    |      | EBI address bus bit 17.              |
|           | PB.10    | MFP2 | O    |      |                                      |
| EBI_ADR18 | PF.7     | MFP2 | O    |      | EBI address bus bit 18.              |
|           | PB.9     | MFP2 | O    |      |                                      |
| EBI_ADR19 | PF.6     | MFP2 | O    |      | EBI address bus bit 19.              |
|           | PB.8     | MFP2 | O    |      |                                      |
| EBI_ALE   | PA.8     | MFP2 | O    |      | EBI address latch enable output pin. |
|           | PE.2     | MFP2 | O    |      |                                      |
| EBI_MCLK  | PA.9     | MFP2 | O    |      | EBI external clock output pin.       |
|           | PE.3     | MFP2 | O    |      |                                      |
| EBI_nCS0  | PD.12    | MFP2 | O    |      | EBI chip select 0 output pin.        |
|           | PF.6     | MFP7 | O    |      |                                      |
|           | PF.3     | MFP2 | O    |      |                                      |
|           | PD.14    | MFP2 | O    |      |                                      |

| Group    | Pin Name       | GPIO  | MFP   | Type | Description                                |
|----------|----------------|-------|-------|------|--------------------------------------------|
| EBI_nCS1 |                | PB.7  | MFP8  | O    |                                            |
|          |                | PD.11 | MFP2  | O    | EBI chip select 1 output pin.              |
|          |                | PF.2  | MFP2  | O    |                                            |
|          |                | PG.5  | MFP2  | O    |                                            |
|          |                | PB.6  | MFP8  | O    |                                            |
| EBI_nCS2 |                | PD.10 | MFP2  | O    | EBI chip select 2 output pin.              |
|          |                | PG.6  | MFP2  | O    |                                            |
| EBI_nRD  |                | PA.11 | MFP2  | O    | EBI read enable output pin.                |
|          |                | PE.5  | MFP2  | O    |                                            |
| EBI_nWR  |                | PA.10 | MFP2  | O    | EBI write enable output pin.               |
|          |                | PE.4  | MFP2  | O    |                                            |
| EBI_nWRH |                | PG.8  | MFP2  | O    | EBI high byte write enable output pin      |
|          |                | PB.6  | MFP2  | O    |                                            |
| EBI_nWRL |                | PG.7  | MFP2  | O    | EBI low byte write enable output pin.      |
|          |                | PB.7  | MFP2  | O    |                                            |
| ECAP0    | ECAP0_IC0      | PA.10 | MFP11 | I    | Enhanced capture unit 0 input 0 pin.       |
|          |                | PE.8  | MFP12 | I    |                                            |
|          | ECAP0_IC1      | PA.9  | MFP11 | I    | Enhanced capture unit 0 input 1 pin.       |
|          |                | PE.9  | MFP12 | I    |                                            |
|          | ECAP0_IC2      | PA.8  | MFP11 | I    | Enhanced capture unit 0 input 2 pin.       |
|          |                | PE.10 | MFP12 | I    |                                            |
| ECAP1    | ECAP1_IC0      | PC.10 | MFP11 | I    | Enhanced capture unit 1 input 0 pin.       |
|          |                | PE.13 | MFP13 | I    |                                            |
|          | ECAP1_IC1      | PC.11 | MFP11 | I    | Enhanced capture unit 1 input 1 pin.       |
|          |                | PE.12 | MFP13 | I    |                                            |
|          | ECAP1_IC2      | PC.12 | MFP11 | I    | Enhanced capture unit 1 input 2 pin.       |
|          |                | PE.11 | MFP13 | I    |                                            |
| EMAC     | EMAC_RMII_MDC  | PE.8  | MFP3  | O    | EMAC RMII PHY Management Clock output pin. |
|          |                | PB.11 | MFP3  | O    |                                            |
|          | EMAC_RMII_MDIO | PE.9  | MFP3  | I/O  | EMAC RMII PHY Management Data pin.         |
|          |                | PB.10 | MFP3  | I/O  |                                            |
|          | EMAC_RMII_RXD0 | PB.4  | MFP4  | I    | EMAC RMII Receive Data bus bit 0.          |
|          |                | PC.7  | MFP3  | I    |                                            |
|          | EMAC_RMII_RXD1 | PB.3  | MFP4  | I    | EMAC RMII Receive Data bus bit 1.          |

| Group | Pin Name         | GPIO  | MFP   | Type | Description                                     |
|-------|------------------|-------|-------|------|-------------------------------------------------|
| EMAC  |                  | PC.6  | MFP3  | I    |                                                 |
|       | EMAC_RMII_CRSDV  | PB.2  | MFP4  | I    | EMAC RMII Carrier Sense/Receive Data input pin. |
|       |                  | PA.7  | MFP3  | I    |                                                 |
|       | EMAC_RMII_RXERR  | PB.1  | MFP4  | I    | EMAC RMII Receive Data Error input pin.         |
|       |                  | PA.6  | MFP3  | I    |                                                 |
|       | EMAC_RMII_TXD0   | PE.10 | MFP3  | O    | EMAC RMII Transmit Data bus bit 0.              |
|       |                  | PB.9  | MFP3  | O    |                                                 |
|       | EMAC_RMII_TXD1   | PE.11 | MFP3  | O    | EMAC RMII Transmit Data bus bit 1.              |
|       |                  | PB.8  | MFP3  | O    |                                                 |
|       | EMAC_RMII_TXEN   | PE.12 | MFP3  | O    | EMAC RMII Transmit Enable output pin.           |
|       |                  | PB.7  | MFP3  | O    |                                                 |
| EPWM0 | EMAC_PPS         | PE.13 | MFP3  | O    | EMAC Pulse Per Second output pin.               |
|       |                  | PB.6  | MFP3  | O    |                                                 |
|       | EMAC_RMII_REFCLK | PB.5  | MFP4  | I    | EMAC RMII reference clock input pin.            |
|       |                  | PC.8  | MFP3  | I    |                                                 |
|       | EPWM0_BRAKE0     | PB.1  | MFP13 | I    | EPWM0 Brake 0 input pin.                        |
|       |                  | PE.8  | MFP11 | I    |                                                 |
|       | EPWM0_BRAKE1     | PB.0  | MFP13 | I    | EPWM0 Brake 1 input pin.                        |
|       |                  | PE.9  | MFP11 | I    |                                                 |
|       | EPWM0_CH0        | PB.5  | MFP11 | I/O  | EPWM0 channel 0 output/capture input.           |
|       |                  | PE.8  | MFP10 | I/O  |                                                 |
|       |                  | PA.5  | MFP13 | I/O  |                                                 |
|       |                  | PE.7  | MFP12 | I/O  |                                                 |
|       |                  | PG.8  | MFP11 | I/O  |                                                 |
|       | EPWM0_CH1        | PB.4  | MFP11 | I/O  | EPWM0 channel 1 output/capture input.           |
|       |                  | PE.9  | MFP10 | I/O  |                                                 |
|       |                  | PA.4  | MFP13 | I/O  |                                                 |
|       |                  | PE.6  | MFP12 | I/O  |                                                 |
|       |                  | PG.7  | MFP11 | I/O  |                                                 |
|       | EPWM0_CH2        | PB.3  | MFP11 | I/O  | EPWM0 channel 2 output/capture input.           |
|       |                  | PE.10 | MFP10 | I/O  |                                                 |
|       |                  | PA.3  | MFP13 | I/O  |                                                 |
|       |                  | PE.5  | MFP12 | I/O  |                                                 |
|       |                  | PG.6  | MFP11 | I/O  |                                                 |

| Group | Pin Name       | GPIO  | MFP   | Type | Description                                   |
|-------|----------------|-------|-------|------|-----------------------------------------------|
| EPWM0 | EPWM0_CH3      | PB.2  | MFP11 | I/O  | EPWM0 channel 3 output/capture input.         |
|       |                | PE.11 | MFP10 | I/O  |                                               |
|       |                | PA.2  | MFP13 | I/O  |                                               |
|       |                | PE.4  | MFP12 | I/O  |                                               |
|       |                | PG.5  | MFP11 | I/O  |                                               |
| EPWM0 | EPWM0_CH4      | PB.1  | MFP11 | I/O  | EPWM0 channel 4 output/capture input.         |
|       |                | PE.12 | MFP10 | I/O  |                                               |
|       |                | PA.1  | MFP13 | I/O  |                                               |
|       |                | PE.3  | MFP12 | I/O  |                                               |
|       |                | PD.14 | MFP11 | I/O  |                                               |
| EPWM0 | EPWM0_CH5      | PB.0  | MFP11 | I/O  | EPWM0 channel 5 output/capture input.         |
|       |                | PE.13 | MFP10 | I/O  |                                               |
|       |                | PA.0  | MFP13 | I/O  |                                               |
|       |                | PE.2  | MFP12 | I/O  |                                               |
|       |                | PH.11 | MFP11 | I/O  |                                               |
| EPWM0 | EPWM0_SYNC_IN  | PA.15 | MFP12 | I    | EPWM0 counter synchronous trigger input pin.  |
|       |                | PC.14 | MFP11 | I    |                                               |
|       | EPWM0_SYNC_OUT | PA.11 | MFP10 | O    | EPWM0 counter synchronous trigger output pin. |
|       |                | PF.5  | MFP9  | O    |                                               |
| EPWM1 | EPWM1_BRAKE0   | PE.10 | MFP11 | I    | EPWM1 Brake 0 input pin.                      |
|       |                | PB.7  | MFP11 | I    |                                               |
|       | EPWM1_BRAKE1   | PE.11 | MFP11 | I    | EPWM1 Brake 1 input pin.                      |
|       |                | PB.6  | MFP11 | I    |                                               |
|       | EPWM1_CH0      | PC.12 | MFP12 | I/O  | EPWM1 channel 0 output/capture input.         |
|       |                | PE.13 | MFP11 | I/O  |                                               |
|       |                | PC.5  | MFP12 | I/O  |                                               |
|       |                | PB.15 | MFP11 | I/O  |                                               |
|       | EPWM1_CH1      | PC.11 | MFP12 | I/O  | EPWM1 channel 1 output/capture input.         |
|       |                | PC.8  | MFP11 | I/O  |                                               |
|       |                | PC.4  | MFP12 | I/O  |                                               |
|       |                | PB.14 | MFP11 | I/O  |                                               |
|       | EPWM1_CH2      | PC.10 | MFP12 | I/O  | EPWM1 channel 2 output/capture input.         |
|       |                | PC.7  | MFP11 | I/O  |                                               |
|       |                | PC.3  | MFP12 | I/O  |                                               |

| Group | Pin Name  | GPIO  | MFP   | Type | Description                           |
|-------|-----------|-------|-------|------|---------------------------------------|
| HSUSB | EPWM1_CH3 | PB.13 | MFP11 | I/O  | EPWM1 channel 3 output/capture input. |
|       |           | PC.9  | MFP12 | I/O  |                                       |
|       |           | PC.6  | MFP11 | I/O  |                                       |
|       |           | PC.2  | MFP12 | I/O  |                                       |
|       | EPWM1_CH4 | PB.12 | MFP11 | I/O  |                                       |
|       |           | PB.1  | MFP12 | I/O  |                                       |
|       |           | PA.7  | MFP11 | I/O  |                                       |
|       |           | PC.1  | MFP12 | I/O  |                                       |
|       | EPWM1_CH5 | PB.7  | MFP12 | I/O  |                                       |
|       |           | PB.0  | MFP12 | I/O  |                                       |
|       |           | PA.6  | MFP11 | I/O  |                                       |
|       |           | PC.0  | MFP12 | I/O  |                                       |
| I2C0  | I2C0_SCL  | PB.6  | MFP12 | I/O  | EPWM1 channel 5 output/capture input. |
|       |           | PB.15 | MFP15 | O    |                                       |
|       |           | PB.10 | MFP14 | O    |                                       |
|       |           | PC.14 | MFP15 | I    |                                       |
|       |           | PB.11 | MFP14 | I    |                                       |
|       |           | PC.12 | MFP4  | I/O  |                                       |
|       |           | PG.0  | MFP4  | I/O  |                                       |
|       |           | PH.2  | MFP6  | I/O  |                                       |
|       | I2C0_SDA  | PF.3  | MFP4  | I/O  | I2C0 clock pin.                       |
|       |           | PE.13 | MFP4  | I/O  |                                       |
|       |           | PA.5  | MFP9  | I/O  |                                       |
|       |           | PC.1  | MFP9  | I/O  |                                       |
|       |           | PD.7  | MFP4  | I/O  |                                       |
|       |           | PB.4  | MFP6  | I/O  |                                       |
|       |           | PC.11 | MFP4  | I/O  |                                       |
|       |           | PG.1  | MFP4  | I/O  |                                       |
|       |           | PH.3  | MFP6  | I/O  |                                       |
|       |           | PF.2  | MFP4  | I/O  |                                       |

| Group | Pin Name    | GPIO  | MFP  | Type | Description                               |
|-------|-------------|-------|------|------|-------------------------------------------|
| I2C0  | I2C0_SMBAL  | PD.6  | MFP4 | I/O  |                                           |
|       |             | PG.2  | MFP4 | O    | I2C0 SMBus SMBALTER pin                   |
|       | I2C0_SMBSUS | PC.3  | MFP9 | O    |                                           |
|       |             | PG.3  | MFP4 | O    | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin) |
|       | PC.2        | MFP9  | O    |      |                                           |
| I2C1  | I2C1_SCL    | PB.1  | MFP9 | I/O  | I2C1 clock pin.                           |
|       |             | PG.2  | MFP5 | I/O  |                                           |
|       |             | PA.7  | MFP8 | I/O  |                                           |
|       |             | PA.3  | MFP9 | I/O  |                                           |
|       |             | PF.0  | MFP3 | I/O  |                                           |
|       |             | PC.5  | MFP9 | I/O  |                                           |
|       |             | PD.5  | MFP4 | I/O  |                                           |
|       |             | PA.12 | MFP4 | I/O  |                                           |
|       |             | PE.1  | MFP8 | I/O  |                                           |
|       |             | PB.11 | MFP7 | I/O  |                                           |
|       | I2C1_SDA    | PB.0  | MFP9 | I/O  | I2C1 data input/output pin.               |
|       |             | PG.3  | MFP5 | I/O  |                                           |
|       |             | PA.6  | MFP8 | I/O  |                                           |
|       |             | PA.2  | MFP9 | I/O  |                                           |
|       |             | PF.1  | MFP3 | I/O  |                                           |
|       |             | PC.4  | MFP9 | I/O  |                                           |
|       |             | PD.4  | MFP4 | I/O  |                                           |
|       |             | PA.13 | MFP4 | I/O  |                                           |
|       |             | PE.0  | MFP8 | I/O  |                                           |
|       |             | PB.10 | MFP7 | I/O  |                                           |
|       | I2C1_SMBAL  | PG.0  | MFP5 | O    | I2C1 SMBus SMBALTER pin                   |
|       |             | PC.7  | MFP8 | O    |                                           |
|       |             | PH.8  | MFP8 | O    |                                           |
|       |             | PB.9  | MFP7 | O    |                                           |
|       | I2C1_SMBSUS | PG.1  | MFP5 | O    | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|       |             | PC.6  | MFP8 | O    |                                           |
|       |             | PH.9  | MFP8 | O    |                                           |
|       |             | PB.8  | MFP7 | O    |                                           |
| I2C2  | I2C2_SCL    | PA.11 | MFP7 | I/O  | I2C2 clock pin.                           |

| Group | Pin Name    | GPIO  | MFP   | Type | Description                               |
|-------|-------------|-------|-------|------|-------------------------------------------|
|       |             | PA.1  | MFP9  | I/O  |                                           |
|       |             | PD.9  | MFP3  | I/O  |                                           |
|       |             | PD.1  | MFP6  | I/O  |                                           |
|       |             | PA.14 | MFP6  | I/O  |                                           |
|       |             | PH.8  | MFP9  | I/O  |                                           |
|       |             | PB.13 | MFP8  | I/O  |                                           |
|       |             | PA.10 | MFP7  | I/O  |                                           |
|       |             | PA.0  | MFP9  | I/O  |                                           |
|       | I2C2_SDA    | PD.8  | MFP3  | I/O  |                                           |
|       |             | PD.0  | MFP6  | I/O  | I2C2 data input/output pin.               |
|       |             | PA.15 | MFP6  | I/O  |                                           |
|       |             | PH.9  | MFP9  | I/O  |                                           |
|       |             | PB.12 | MFP8  | I/O  |                                           |
|       | I2C2_SMBAL  | PB.15 | MFP8  | O    | I2C2 SMBus SMBALTER pin                   |
|       | I2C2_SMBSUS | PB.14 | MFP8  | O    | I2C2 SMBus SMBSUS pin (PMBus CONTROL pin) |
| I2S0  | I2S0_BCLK   | PB.5  | MFP10 | O    | I2S0 bit clock output pin.                |
|       |             | PF.10 | MFP4  | O    |                                           |
|       |             | PE.8  | MFP4  | O    |                                           |
|       |             | PC.4  | MFP6  | O    |                                           |
|       |             | PA.12 | MFP2  | O    |                                           |
|       |             | PE.1  | MFP5  | O    |                                           |
| I2S0  | I2S0_DI     | PB.3  | MFP10 | I    | I2S0 data input pin.                      |
|       |             | PF.8  | MFP4  | I    |                                           |
|       |             | PE.10 | MFP4  | I    |                                           |
|       |             | PC.2  | MFP6  | I    |                                           |
|       |             | PA.14 | MFP2  | I    |                                           |
|       |             | PH.8  | MFP5  | I    |                                           |
| I2S0  | I2S0_DO     | PB.2  | MFP10 | O    | I2S0 data output pin.                     |
|       |             | PF.7  | MFP4  | O    |                                           |
|       |             | PE.11 | MFP4  | O    |                                           |
|       |             | PC.1  | MFP6  | O    |                                           |
|       |             | PA.15 | MFP2  | O    |                                           |
|       |             | PH.9  | MFP5  | O    |                                           |
|       | I2S0_LRCK   | PB.1  | MFP10 | O    | I2S0 left right channel clock output pin. |

| Group     | Pin Name                                      | GPIO  | MFP   | Type | Description                                 |
|-----------|-----------------------------------------------|-------|-------|------|---------------------------------------------|
| I2S0_MCLK | PF.6<br>PE.12<br>PC.0<br>PH.10                | PF.6  | MFP4  | O    | I2S0 master clock output pin.               |
|           |                                               | PE.12 | MFP4  | O    |                                             |
|           |                                               | PC.0  | MFP6  | O    |                                             |
|           |                                               | PH.10 | MFP5  | O    |                                             |
|           | PB.4<br>PF.9<br>PE.9<br>PC.3<br>PA.13<br>PE.0 | PB.4  | MFP10 | O    |                                             |
|           |                                               | PF.9  | MFP4  | O    |                                             |
|           |                                               | PE.9  | MFP4  | O    |                                             |
|           |                                               | PC.3  | MFP6  | O    |                                             |
|           |                                               | PA.13 | MFP2  | O    |                                             |
|           |                                               | PE.0  | MFP5  | O    |                                             |
| ICE       | ICE_CLK                                       | PF.1  | MFP14 | I    | Serial wired debugger clock pin.            |
|           | ICE_DAT                                       | PF.0  | MFP14 | O    | Serial wired debugger data pin.             |
| INT0      | INT0                                          | PB.5  | MFP15 | I    | External interrupt 0 input pin.             |
|           |                                               | PA.6  | MFP15 | I    |                                             |
| INT1      | INT1                                          | PB.4  | MFP15 | I    | External interrupt 1 input pin.             |
|           |                                               | PA.7  | MFP15 | I    |                                             |
| INT2      | INT2                                          | PB.3  | MFP15 | I    | External interrupt 2 input pin.             |
|           |                                               | PC.6  | MFP15 | I    |                                             |
| INT3      | INT3                                          | PB.2  | MFP15 | I    | External interrupt 3 input pin.             |
|           |                                               | PC.7  | MFP15 | I    |                                             |
| INT4      | INT4                                          | PA.8  | MFP15 | I    | External interrupt 4 input pin.             |
|           |                                               | PB.6  | MFP13 | I    |                                             |
| INT5      | INT5                                          | PD.12 | MFP15 | I    | External interrupt 5 input pin.             |
|           |                                               | PB.7  | MFP13 | I    |                                             |
| INT6      | INT6                                          | PD.11 | MFP15 | I    | External interrupt 6 input pin.             |
|           |                                               | PB.8  | MFP13 | I    |                                             |
| INT7      | INT7                                          | PD.10 | MFP15 | I    | External interrupt 7 input pin.             |
|           |                                               | PB.9  | MFP13 | I    |                                             |
| OPA0      | OPA0_N                                        | PB.1  | MFP1  | A    | Operational amplifier 0 negative input pin. |
|           | OPA0_O                                        | PB.2  | MFP1  | A    | Operational amplifier 0 output pin.         |
|           | OPA0_P                                        | PB.0  | MFP1  | A    | Operational amplifier 0 positive input pin. |
| OPA1      | OPA1_N                                        | PA.9  | MFP1  | A    | Operational amplifier 1 negative input pin. |
|           | OPA1_O                                        | PA.10 | MFP1  | A    | Operational amplifier 1 output pin.         |
|           | OPA1_P                                        | PA.8  | MFP1  | A    | Operational amplifier 1 positive input pin. |

| Group | Pin Name    | GPIO  | MFP   | Type | Description                                 |
|-------|-------------|-------|-------|------|---------------------------------------------|
| OPA2  | OPA2_N      | PD.11 | MFP1  | A    | Operational amplifier 2 negative input pin. |
|       | OPA2_O      | PD.12 | MFP1  | A    | Operational amplifier 2 output pin.         |
|       | OPA2_P      | PD.10 | MFP1  | A    | Operational amplifier 2 positive input pin. |
| QEI0  | QEI0_A      | PD.11 | MFP10 | I    | Quadrature encoder 0 phase A input          |
|       |             | PA.4  | MFP14 | I    |                                             |
|       |             | PE.3  | MFP11 | I    |                                             |
|       | QEI0_B      | PD.10 | MFP10 | I    | Quadrature encoder 0 phase B input          |
|       |             | PA.3  | MFP14 | I    |                                             |
|       |             | PE.2  | MFP11 | I    |                                             |
| QEI1  | QEI1_A      | PD.12 | MFP10 | I    | Quadrature encoder 1 phase A input          |
|       |             | PA.5  | MFP14 | I    |                                             |
|       |             | PE.4  | MFP11 | I    |                                             |
|       | QEI1_B      | PA.9  | MFP10 | I    | Quadrature encoder 1 phase B input          |
|       |             | PA.13 | MFP12 | I    |                                             |
|       |             | PE.6  | MFP11 | I    |                                             |
| QSPI0 | QSPI0_CLK   | PA.8  | MFP10 | I    | Quad SPI0 serial clock pin.                 |
|       |             | PA.14 | MFP12 | I    |                                             |
|       |             | PE.5  | MFP11 | I    |                                             |
|       |             | PA.10 | MFP10 | I    |                                             |
|       |             | PA.12 | MFP12 | I    |                                             |
|       | QSPI0_MISO0 | PA.12 | MFP11 | I    | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|       |             | PC.1  | MFP3  | I/O  |                                             |
|       |             | PE.1  | MFP4  | I/O  |                                             |
| QSPI0 | QSPI0_MISO1 | PA.1  | MFP3  | I/O  | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|       |             | PC.1  | MFP4  | I/O  |                                             |
|       |             | PE.1  | MFP3  | I/O  |                                             |
|       | QSPI0_MOSI0 | PA.5  | MFP3  | I/O  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|       |             | PC.5  | MFP4  | I/O  |                                             |
|       |             | PH.10 | MFP3  | I/O  |                                             |
| QSPI0 | QSPI0_MOSI0 | PA.0  | MFP3  | I/O  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|       |             | PC.0  | MFP4  | I/O  |                                             |

| Group | Pin Name    | GPIO  | MFP  | Type | Description                                 |
|-------|-------------|-------|------|------|---------------------------------------------|
| SC0   | QSPI0_MOSI1 | PE.0  | MFP3 | I/O  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|       |             | PA.4  | MFP3 | I/O  |                                             |
|       |             | PC.4  | MFP4 | I/O  |                                             |
|       |             | PH.11 | MFP3 | I/O  |                                             |
|       | QSPI0_SS    | PA.3  | MFP3 | I/O  | Quad SPI0 slave select pin.                 |
|       |             | PC.3  | MFP4 | I/O  |                                             |
|       |             | PH.9  | MFP3 | I/O  |                                             |
|       | SC0_CLK     | PB.5  | MFP9 | O    | Smart Card 0 clock pin.                     |
|       |             | PF.6  | MFP3 | O    |                                             |
|       |             | PA.0  | MFP6 | O    |                                             |
|       |             | PE.2  | MFP6 | O    |                                             |
|       | SC0_DAT     | PB.4  | MFP9 | I/O  | Smart Card 0 data pin.                      |
|       |             | PF.7  | MFP3 | I/O  |                                             |
|       |             | PA.1  | MFP6 | I/O  |                                             |
|       |             | PE.3  | MFP6 | I/O  |                                             |
|       | SC0_PWR     | PB.2  | MFP9 | O    | Smart Card 0 power pin.                     |
|       |             | PF.9  | MFP3 | O    |                                             |
|       |             | PA.3  | MFP6 | O    |                                             |
|       |             | PE.5  | MFP6 | O    |                                             |
|       | SC0_RST     | PB.3  | MFP9 | O    | Smart Card 0 reset pin.                     |
|       |             | PF.8  | MFP3 | O    |                                             |
|       |             | PA.2  | MFP6 | O    |                                             |
|       |             | PE.4  | MFP6 | O    |                                             |
|       | SC0_nCD     | PC.12 | MFP9 | I    | Smart Card 0 card detect pin.               |
|       |             | PF.10 | MFP3 | I    |                                             |
|       |             | PA.4  | MFP6 | I    |                                             |
|       |             | PE.6  | MFP6 | I    |                                             |
| SC1   | SC1_CLK     | PC.0  | MFP5 | O    | Smart Card 1 clock pin.                     |
|       |             | PD.4  | MFP8 | O    |                                             |
|       |             | PG.8  | MFP4 | O    |                                             |
|       |             | PB.12 | MFP3 | O    |                                             |
|       | SC1_DAT     | PC.1  | MFP5 | I/O  | Smart Card 1 data pin.                      |
|       |             | PD.5  | MFP8 | I/O  |                                             |
|       |             | PG.7  | MFP4 | I/O  |                                             |

| Group | Pin Name | GPIO  | MFP  | Type | Description                   |
|-------|----------|-------|------|------|-------------------------------|
| SC1   | SC1_PWR  | PB.13 | MFP3 | I/O  | Smart Card 1 power pin.       |
|       |          | PC.3  | MFP5 | O    |                               |
|       |          | PD.7  | MFP8 | O    |                               |
|       |          | PG.5  | MFP4 | O    |                               |
|       |          | PB.15 | MFP3 | O    |                               |
|       | SC1_RST  | PC.2  | MFP5 | O    |                               |
|       |          | PD.6  | MFP8 | O    |                               |
|       |          | PG.6  | MFP4 | O    |                               |
|       |          | PB.14 | MFP3 | O    |                               |
|       | SC1_nCD  | PC.4  | MFP5 | I    |                               |
|       |          | PD.3  | MFP8 | I    |                               |
|       |          | PD.14 | MFP4 | I    |                               |
|       |          | PC.14 | MFP3 | I    |                               |
| SC2   | SC2_CLK  | PA.8  | MFP3 | O    | Smart Card 2 clock pin.       |
|       |          | PA.6  | MFP6 | O    |                               |
|       |          | PD.0  | MFP7 | O    |                               |
|       |          | PA.15 | MFP7 | O    |                               |
|       |          | PE.0  | MFP4 | O    |                               |
|       | SC2_DAT  | PA.9  | MFP3 | I/O  |                               |
|       |          | PA.7  | MFP6 | I/O  |                               |
|       |          | PD.1  | MFP7 | I/O  |                               |
|       |          | PA.14 | MFP7 | I/O  |                               |
|       |          | PE.1  | MFP4 | I/O  |                               |
|       | SC2_PWR  | PA.11 | MFP3 | O    |                               |
|       |          | PC.7  | MFP6 | O    |                               |
|       |          | PD.3  | MFP7 | O    |                               |
|       |          | PA.12 | MFP7 | O    |                               |
|       |          | PH.8  | MFP4 | O    |                               |
|       | SC2_RST  | PA.10 | MFP3 | O    | Smart Card 2 reset pin.       |
|       |          | PC.6  | MFP6 | O    |                               |
|       |          | PD.2  | MFP7 | O    |                               |
|       |          | PA.13 | MFP7 | O    |                               |
|       |          | PH.9  | MFP4 | O    |                               |
|       | SC2_nCD  | PC.13 | MFP3 | I    | Smart Card 2 card detect pin. |

| Group | Pin Name | GPIO  | MFP  | Type | Description                   |
|-------|----------|-------|------|------|-------------------------------|
|       |          | PA.5  | MFP6 | I    |                               |
|       |          | PD.13 | MFP7 | I    |                               |
|       |          | PH.10 | MFP4 | I    |                               |
| SD0   | SD0_CLK  | PB.1  | MFP3 | O    | SD/SDIO0 clock output pin     |
|       |          | PE.6  | MFP3 | O    |                               |
|       | SD0_CMD  | PB.0  | MFP3 | I/O  | SD/SDIO0 command/response pin |
|       |          | PE.7  | MFP3 | I/O  |                               |
|       | SD0_DAT0 | PB.2  | MFP3 | I/O  | SD/SDIO0 data line bit 0.     |
|       |          | PE.2  | MFP3 | I/O  |                               |
|       | SD0_DAT1 | PB.3  | MFP3 | I/O  | SD/SDIO0 data line bit 1.     |
|       |          | PE.3  | MFP3 | I/O  |                               |
|       | SD0_DAT2 | PB.4  | MFP3 | I/O  | SD/SDIO0 data line bit 2.     |
|       |          | PE.4  | MFP3 | I/O  |                               |
| SD1   | SD1_CLK  | PA.4  | MFP5 | O    | SD/SDIO1 clock output pin     |
|       |          | PG.14 | MFP3 | O    |                               |
|       |          | PB.6  | MFP7 | O    |                               |
|       | SD1_CMD  | PA.5  | MFP5 | I/O  | SD/SDIO1 command/response pin |
|       |          | PG.13 | MFP3 | I/O  |                               |
|       |          | PB.7  | MFP7 | I/O  |                               |
|       | SD1_DAT0 | PA.8  | MFP5 | I/O  | SD/SDIO1 data line bit 0.     |
|       |          | PA.0  | MFP5 | I/O  |                               |
|       |          | PG.12 | MFP3 | I/O  |                               |
|       | SD1_DAT1 | PA.9  | MFP5 | I/O  | SD/SDIO1 data line bit 1.     |
|       |          | PA.1  | MFP5 | I/O  |                               |
|       |          | PG.11 | MFP3 | I/O  |                               |
|       | SD1_DAT2 | PA.10 | MFP5 | I/O  | SD/SDIO1 data line bit 2.     |
|       |          | PA.2  | MFP5 | I/O  |                               |
|       |          | PG.10 | MFP3 | I/O  |                               |
|       | SD1_DAT3 | PA.11 | MFP5 | I/O  | SD/SDIO1 data line bit 3.     |
|       |          | PA.3  | MFP5 | I/O  |                               |

| Group | Pin Name     | GPIO  | MFP  | Type | Description                           |
|-------|--------------|-------|------|------|---------------------------------------|
| SPI0  | SD1_nCD      | PG.9  | MFP3 | I/O  | SD/SDIO1 card detect input pin        |
|       |              | PA.6  | MFP5 | I    |                                       |
|       |              | PE.14 | MFP5 | I    |                                       |
|       |              | PG.15 | MFP3 | I    |                                       |
| SPI0  | SPI0_CLK     | PF.8  | MFP5 | I/O  | SPI0 serial clock pin.                |
|       |              | PA.2  | MFP4 | I/O  |                                       |
|       |              | PD.2  | MFP4 | I/O  |                                       |
|       |              | PB.14 | MFP4 | I/O  |                                       |
|       | SPI0_I2SMCLK | PB.0  | MFP8 | I/O  | SPI0 I2S master clock output pin      |
|       |              | PF.10 | MFP5 | I/O  |                                       |
|       |              | PA.4  | MFP4 | I/O  |                                       |
|       |              | PD.13 | MFP4 | I/O  |                                       |
|       |              | PC.14 | MFP4 | I/O  |                                       |
|       |              | PB.11 | MFP9 | I/O  |                                       |
|       | SPI0_MISO    | PF.7  | MFP5 | I/O  | SPI0 MISO (Master In, Slave Out) pin. |
|       |              | PA.1  | MFP4 | I/O  |                                       |
|       |              | PD.1  | MFP4 | I/O  |                                       |
|       |              | PB.13 | MFP4 | I/O  |                                       |
|       | SPI0_MOSI    | PF.6  | MFP5 | I/O  | SPI0 MOSI (Master Out, Slave In) pin. |
|       |              | PA.0  | MFP4 | I/O  |                                       |
|       |              | PD.0  | MFP4 | I/O  |                                       |
|       |              | PB.12 | MFP4 | I/O  |                                       |
|       | SPI0_SS      | PF.9  | MFP5 | I/O  | SPI0 slave select pin.                |
|       |              | PA.3  | MFP4 | I/O  |                                       |
|       |              | PD.3  | MFP4 | I/O  |                                       |
|       |              | PB.15 | MFP4 | I/O  |                                       |
| SPI1  | SPI1_CLK     | PB.3  | MFP5 | I/O  | SPI1 serial clock pin.                |
|       |              | PH.6  | MFP3 | I/O  |                                       |
|       |              | PA.7  | MFP4 | I/O  |                                       |
|       |              | PC.1  | MFP7 | I/O  |                                       |
|       |              | PD.5  | MFP5 | I/O  |                                       |
|       |              | PH.8  | MFP6 | I/O  |                                       |
|       | SPI1_I2SMCLK | PB.1  | MFP5 | I/O  | SPI1 I2S master clock output pin      |
|       |              | PH.3  | MFP3 | I/O  |                                       |

| Group | Pin Name     | GPIO  | MFP  | Type | Description                           |
|-------|--------------|-------|------|------|---------------------------------------|
| SPI1  |              | PA.5  | MFP4 | I/O  |                                       |
|       |              | PC.4  | MFP7 | I/O  |                                       |
|       |              | PD.13 | MFP5 | I/O  |                                       |
|       |              | PH.10 | MFP6 | I/O  |                                       |
|       | SPI1_MISO    | PB.5  | MFP5 | I/O  |                                       |
|       |              | PH.4  | MFP3 | I/O  |                                       |
|       |              | PC.7  | MFP4 | I/O  |                                       |
|       |              | PC.3  | MFP7 | I/O  |                                       |
|       |              | PD.7  | MFP5 | I/O  |                                       |
|       |              | PE.1  | MFP6 | I/O  |                                       |
|       | SPI1_MOSI    | PB.4  | MFP5 | I/O  | SPI1 MISO (Master In, Slave Out) pin. |
|       |              | PH.5  | MFP3 | I/O  |                                       |
|       |              | PC.6  | MFP4 | I/O  |                                       |
|       |              | PC.2  | MFP7 | I/O  |                                       |
|       |              | PD.6  | MFP5 | I/O  |                                       |
|       |              | PE.0  | MFP6 | I/O  |                                       |
|       | SPI1_SS      | PB.2  | MFP5 | I/O  | SPI1 slave select pin.                |
|       |              | PH.7  | MFP3 | I/O  |                                       |
|       |              | PA.6  | MFP4 | I/O  |                                       |
|       |              | PC.0  | MFP7 | I/O  |                                       |
|       |              | PD.4  | MFP5 | I/O  |                                       |
|       |              | PH.9  | MFP6 | I/O  |                                       |
| SPI2  | SPI2_CLK     | PA.10 | MFP4 | I/O  | SPI2 serial clock pin.                |
|       |              | PG.3  | MFP3 | I/O  |                                       |
|       |              | PE.8  | MFP5 | I/O  |                                       |
|       |              | PA.13 | MFP5 | I/O  |                                       |
|       | SPI2_I2SMCLK | PC.13 | MFP4 | I/O  | SPI2 I2S master clock output pin      |
|       |              | PG.1  | MFP3 | I/O  |                                       |
|       |              | PE.12 | MFP5 | I/O  |                                       |
|       | SPI2_MISO    | PA.9  | MFP4 | I/O  | SPI2 MISO (Master In, Slave Out) pin. |
|       |              | PG.4  | MFP3 | I/O  |                                       |
|       |              | PE.9  | MFP5 | I/O  |                                       |
|       |              | PA.14 | MFP5 | I/O  |                                       |
|       | SPI2_MOSI    | PA.8  | MFP4 | I/O  | SPI2 MOSI (Master Out, Slave In) pin. |

| Group | Pin Name     | GPIO  | MFP   | Type | Description                           |
|-------|--------------|-------|-------|------|---------------------------------------|
| SPI3  |              | PF.11 | MFP3  | I/O  |                                       |
|       |              | PE.10 | MFP5  | I/O  |                                       |
|       |              | PA.15 | MFP5  | I/O  |                                       |
|       | SPI2_SS      | PA.11 | MFP4  | I/O  |                                       |
|       |              | PG.2  | MFP3  | I/O  |                                       |
|       |              | PE.11 | MFP5  | I/O  |                                       |
|       |              | PA.12 | MFP5  | I/O  |                                       |
|       | SPI3_CLK     | PC.10 | MFP6  | I/O  | SPI2 slave select pin.                |
|       |              | PE.4  | MFP5  | I/O  |                                       |
|       |              | PG.6  | MFP3  | I/O  |                                       |
|       |              | PB.11 | MFP11 | I/O  |                                       |
|       | SPI3_I2SMCLK | PB.1  | MFP6  | I/O  | SPI3 serial clock pin.                |
|       |              | PE.6  | MFP5  | I/O  |                                       |
|       |              | PD.14 | MFP3  | I/O  |                                       |
|       | SPI3_MISO    | PC.12 | MFP6  | I/O  | SPI3 I2S master clock output pin      |
|       |              | PE.3  | MFP5  | I/O  |                                       |
|       |              | PG.7  | MFP3  | I/O  |                                       |
|       |              | PB.9  | MFP11 | I/O  |                                       |
|       | SPI3_MOSI    | PC.11 | MFP6  | I/O  | SPI3 MISO (Master In, Slave Out) pin. |
|       |              | PE.2  | MFP5  | I/O  |                                       |
|       |              | PG.8  | MFP3  | I/O  |                                       |
|       |              | PB.8  | MFP11 | I/O  |                                       |
|       | SPI3_SS      | PC.9  | MFP6  | I/O  | SPI3 slave select pin.                |
|       |              | PE.5  | MFP5  | I/O  |                                       |
|       |              | PG.5  | MFP3  | I/O  |                                       |
|       |              | PB.10 | MFP11 | I/O  |                                       |
| SPIM  | SPIM_CLK     | PA.2  | MFP2  | I/O  | SPIM serial clock pin.                |
|       |              | PC.2  | MFP3  | I/O  |                                       |
|       |              | PG.12 | MFP4  | I/O  |                                       |
|       |              | PE.4  | MFP4  | I/O  |                                       |
|       | SPIM_D2      | PA.5  | MFP2  | I/O  | SPIM data 2 pin for Quad Mode I/O.    |
|       |              | PC.5  | MFP3  | I/O  |                                       |
|       |              | PG.9  | MFP4  | I/O  |                                       |
|       |              | PE.7  | MFP4  | I/O  |                                       |

| Group   | Pin Name  | GPIO  | MFP   | Type | Description                                      |
|---------|-----------|-------|-------|------|--------------------------------------------------|
|         | SPIM_D3   | PA.4  | MFP2  | I/O  | SPIM data 3 pin for Quad Mode I/O.               |
|         |           | PC.4  | MFP3  | I/O  |                                                  |
|         |           | PG.10 | MFP4  | I/O  |                                                  |
|         |           | PE.6  | MFP4  | I/O  |                                                  |
|         | SPIM_MISO | PA.1  | MFP2  | I/O  | SPIM MISO (Master In, Slave Out) pin.            |
|         |           | PC.1  | MFP3  | I/O  |                                                  |
|         |           | PG.13 | MFP4  | I/O  |                                                  |
|         |           | PE.3  | MFP4  | I/O  |                                                  |
|         | SPIM_MOSI | PA.0  | MFP2  | I/O  | SPIM MOSI (Master Out, Slave In) pin.            |
|         |           | PC.0  | MFP3  | I/O  |                                                  |
|         |           | PG.14 | MFP4  | I/O  |                                                  |
|         |           | PE.2  | MFP4  | I/O  |                                                  |
|         | SPIM_SS   | PA.3  | MFP2  | I/O  | SPIM slave select pin.                           |
|         |           | PC.3  | MFP3  | I/O  |                                                  |
|         |           | PG.11 | MFP4  | I/O  |                                                  |
|         |           | PE.5  | MFP4  | I/O  |                                                  |
| TAMPER0 | TAMPER0   | PF.6  | MFP10 | I/O  | TAMPER detector loop pin 0.                      |
| TAMPER1 | TAMPER1   | PF.7  | MFP10 | I/O  | TAMPER detector loop pin 1.                      |
| TAMPER2 | TAMPER2   | PF.8  | MFP10 | I/O  | TAMPER detector loop pin 2.                      |
| TAMPER3 | TAMPER3   | PF.9  | MFP10 | I/O  | TAMPER detector loop pin 3.                      |
| TAMPER4 | TAMPER4   | PF.10 | MFP10 | I/O  | TAMPER detector loop pin 4.                      |
| TAMPER5 | TAMPER5   | PF.11 | MFP10 | I/O  | TAMPER detector loop pin 5.                      |
| TM0     | TM0       | PB.5  | MFP14 | I/O  | Timer0 event counter input/toggle output pin.    |
|         |           | PG.2  | MFP13 | I/O  |                                                  |
|         |           | PC.7  | MFP14 | I/O  |                                                  |
|         | TM0_EXT   | PA.11 | MFP13 | I/O  | Timer0 external capture input/toggle output pin. |
|         |           | PH.0  | MFP13 | I/O  |                                                  |
|         |           | PB.15 | MFP13 | I/O  |                                                  |
| TM1     | TM1       | PB.4  | MFP14 | I/O  | Timer1 event counter input/toggle output pin.    |
|         |           | PG.3  | MFP13 | I/O  |                                                  |
|         |           | PC.6  | MFP14 | I/O  |                                                  |
|         |           | PC.14 | MFP13 | I/O  |                                                  |
|         | TM1_EXT   | PA.10 | MFP13 | I/O  | Timer1 external capture input/toggle output pin. |
|         |           | PH.1  | MFP13 | I/O  |                                                  |

| Group | Pin Name    | GPIO  | MFP   | Type | Description                                      |
|-------|-------------|-------|-------|------|--------------------------------------------------|
|       |             | PB.14 | MFP13 | I/O  |                                                  |
| TM2   | TM2         | PB.3  | MFP14 | I/O  | Timer2 event counter input/toggle output pin.    |
|       |             | PG.4  | MFP13 | I/O  |                                                  |
|       |             | PA.7  | MFP14 | I/O  |                                                  |
|       |             | PD.0  | MFP14 | I/O  |                                                  |
| TM3   | TM2_EXT     | PA.9  | MFP13 | I/O  | Timer2 external capture input/toggle output pin. |
|       |             | PH.2  | MFP13 | I/O  |                                                  |
|       |             | PB.13 | MFP13 | I/O  |                                                  |
|       |             | PA.2  | MFP14 | I/O  |                                                  |
| TM3   | TM3         | PF.11 | MFP13 | I/O  | Timer3 event counter input/toggle output pin.    |
|       |             | PA.6  | MFP14 | I/O  |                                                  |
|       | TM3_EXT     | PA.8  | MFP13 | I/O  | Timer3 external capture input/toggle output pin. |
|       |             | PH.3  | MFP13 | I/O  |                                                  |
| TRACE | TRACE_CLK   | PE.8  | MFP14 | O    | ETM Trace Clock output pin                       |
|       | TRACE_DATA0 | PE.9  | MFP14 | O    | ETM Trace Data 0 output pin                      |
|       | TRACE_DATA1 | PE.10 | MFP14 | O    | ETM Trace Data 1 output pin                      |
|       | TRACE_DATA2 | PE.11 | MFP14 | O    | ETM Trace Data 2 output pin                      |
|       | TRACE_DATA3 | PE.12 | MFP14 | O    | ETM Trace Data 3 output pin                      |
| UART0 | UART0_RXD   | PC.11 | MFP3  | I    | UART0 data receiver input pin.                   |
|       |             | PF.2  | MFP3  | I    |                                                  |
|       |             | PA.6  | MFP7  | I    |                                                  |
|       |             | PA.0  | MFP7  | I    |                                                  |
|       |             | PD.2  | MFP9  | I    |                                                  |
|       |             | PA.15 | MFP3  | I    |                                                  |
|       |             | PH.11 | MFP8  | I    |                                                  |
|       |             | PB.12 | MFP6  | I    |                                                  |
|       | UART0_TXD   | PB.8  | MFP5  | I    | UART0 data transmitter output pin.               |
|       |             | PC.12 | MFP3  | O    |                                                  |
|       |             | PF.3  | MFP3  | O    |                                                  |
|       |             | PA.7  | MFP7  | O    |                                                  |
|       |             | PA.1  | MFP7  | O    |                                                  |

| Group | Pin Name   | GPIO  | MFP   | Type | Description                        |
|-------|------------|-------|-------|------|------------------------------------|
| UART0 |            | PH.10 | MFP8  | O    | UART0 clear to Send input pin.     |
|       |            | PB.13 | MFP6  | O    |                                    |
|       |            | PB.9  | MFP5  | O    |                                    |
|       | UART0_nCTS | PC.7  | MFP7  | I    |                                    |
|       |            | PA.5  | MFP7  | I    |                                    |
|       |            | PB.15 | MFP6  | I    |                                    |
|       |            | PB.11 | MFP5  | I    |                                    |
|       | UART0_nRTS | PC.6  | MFP7  | O    | UART0 request to Send output pin.  |
|       |            | PA.4  | MFP7  | O    |                                    |
|       |            | PB.14 | MFP6  | O    |                                    |
|       |            | PB.10 | MFP5  | O    |                                    |
| UART1 | UART1_RXD  | PB.2  | MFP6  | I    | UART1 data receiver input pin.     |
|       |            | PA.8  | MFP7  | I    |                                    |
|       |            | PD.10 | MFP3  | I    |                                    |
|       |            | PG.1  | MFP8  | I    |                                    |
|       |            | PC.8  | MFP8  | I    |                                    |
|       |            | PA.2  | MFP8  | I    |                                    |
|       |            | PF.1  | MFP2  | I    |                                    |
|       |            | PD.6  | MFP3  | I    |                                    |
|       |            | PH.9  | MFP10 | I    |                                    |
|       |            | PB.6  | MFP6  | I    |                                    |
|       | UART1_TXD  | PB.3  | MFP6  | O    | UART1 data transmitter output pin. |
|       |            | PA.9  | MFP7  | O    |                                    |
|       |            | PD.11 | MFP3  | O    |                                    |
|       |            | PG.0  | MFP8  | O    |                                    |
|       |            | PE.13 | MFP8  | O    |                                    |
|       |            | PA.3  | MFP8  | O    |                                    |
|       |            | PF.0  | MFP2  | O    |                                    |
|       |            | PD.7  | MFP3  | O    |                                    |
|       |            | PH.8  | MFP10 | O    |                                    |
|       |            | PB.7  | MFP6  | O    |                                    |
|       | UART1_nCTS | PE.11 | MFP8  | I    | UART1 clear to Send input pin.     |
|       |            | PA.1  | MFP8  | I    |                                    |
|       |            | PB.9  | MFP6  | I    |                                    |

| Group | Pin Name   | GPIO  | MFP   | Type | Description                        |
|-------|------------|-------|-------|------|------------------------------------|
|       | UART1_nRTS | PE.12 | MFP8  | O    | UART1 request to Send output pin.  |
|       |            | PA.0  | MFP8  | O    |                                    |
|       |            | PB.8  | MFP6  | O    |                                    |
| UART2 | UART2_RXD  | PB.0  | MFP7  | I    | UART2 data receiver input pin.     |
|       |            | PD.12 | MFP7  | I    |                                    |
|       |            | PG.0  | MFP6  | I    |                                    |
|       |            | PF.5  | MFP2  | I    |                                    |
|       |            | PE.9  | MFP7  | I    |                                    |
|       |            | PE.15 | MFP3  | I    |                                    |
|       |            | PC.4  | MFP8  | I    |                                    |
|       |            | PC.0  | MFP8  | I    |                                    |
|       | UART2_TXD  | PB.1  | MFP7  | O    | UART2 data transmitter output pin. |
|       |            | PC.13 | MFP7  | O    |                                    |
|       |            | PG.1  | MFP6  | O    |                                    |
|       |            | PF.4  | MFP2  | O    |                                    |
|       |            | PE.8  | MFP7  | O    |                                    |
|       |            | PE.14 | MFP3  | O    |                                    |
|       |            | PC.5  | MFP8  | O    |                                    |
|       |            | PC.1  | MFP8  | O    |                                    |
|       | UART2_nCTS | PF.5  | MFP4  | I    | UART2 clear to Send input pin.     |
|       |            | PD.9  | MFP4  | I    |                                    |
|       |            | PC.2  | MFP8  | I    |                                    |
|       | UART2_nRTS | PF.4  | MFP4  | O    | UART2 request to Send output pin.  |
|       |            | PD.8  | MFP4  | O    |                                    |
|       |            | PC.3  | MFP8  | O    |                                    |
| UART3 | UART3_RXD  | PC.9  | MFP7  | I    | UART3 data receiver input pin.     |
|       |            | PE.11 | MFP7  | I    |                                    |
|       |            | PC.2  | MFP11 | I    |                                    |
|       |            | PD.0  | MFP5  | I    |                                    |
|       |            | PE.0  | MFP7  | I    |                                    |
|       |            | PB.14 | MFP7  | I    |                                    |
|       | UART3_TXD  | PC.10 | MFP7  | O    | UART3 data transmitter output pin. |
|       |            | PE.10 | MFP7  | O    |                                    |
|       |            | PC.3  | MFP11 | O    |                                    |

| Group | Pin Name   | GPIO  | MFP   | Type | Description                        |
|-------|------------|-------|-------|------|------------------------------------|
| UART4 |            | PD.1  | MFP5  | O    | UART3 clear to Send input pin.     |
|       |            | PE.1  | MFP7  | O    |                                    |
|       |            | PB.15 | MFP7  | O    |                                    |
|       | UART3_nCTS | PD.2  | MFP5  | I    |                                    |
|       |            | PH.9  | MFP7  | I    |                                    |
|       |            | PB.12 | MFP7  | I    |                                    |
|       | UART3_nRTS | PD.3  | MFP5  | O    | UART3 request to Send output pin.  |
|       |            | PH.8  | MFP7  | O    |                                    |
|       |            | PB.13 | MFP7  | O    |                                    |
|       | UART4_RXD  | PF.6  | MFP6  | I    | UART4 data receiver input pin.     |
|       |            | PH.3  | MFP5  | I    |                                    |
|       |            | PC.6  | MFP5  | I    |                                    |
|       |            | PA.2  | MFP7  | I    |                                    |
|       |            | PC.4  | MFP11 | I    |                                    |
|       |            | PA.13 | MFP3  | I    |                                    |
|       |            | PH.11 | MFP7  | I    |                                    |
|       |            | PB.10 | MFP6  | I    |                                    |
|       | UART4_TXD  | PF.7  | MFP6  | O    | UART4 data transmitter output pin. |
|       |            | PH.2  | MFP5  | O    |                                    |
|       |            | PC.7  | MFP5  | O    |                                    |
|       |            | PA.3  | MFP7  | O    |                                    |
|       |            | PC.5  | MFP11 | O    |                                    |
|       |            | PA.12 | MFP3  | O    |                                    |
|       |            | PH.10 | MFP7  | O    |                                    |
|       |            | PB.11 | MFP6  | O    |                                    |
|       | UART4_nCTS | PC.8  | MFP5  | I    | UART4 clear to Send input pin.     |
|       |            | PE.1  | MFP9  | I    |                                    |
|       | UART4_nRTS | PE.13 | MFP5  | O    | UART4 request to Send output pin.  |
|       |            | PE.0  | MFP9  | O    |                                    |
| UART5 | UART5_RXD  | PB.4  | MFP7  | I    | UART5 data receiver input pin.     |
|       |            | PH.1  | MFP4  | I    |                                    |
|       |            | PA.4  | MFP8  | I    |                                    |
|       |            | PE.6  | MFP8  | I    |                                    |
|       | UART5_TXD  | PB.5  | MFP7  | O    | UART5 data transmitter output pin. |

| Group | Pin Name    | GPIO  | MFP   | Type | Description                             |
|-------|-------------|-------|-------|------|-----------------------------------------|
| USB   |             | PH.0  | MFP4  | O    |                                         |
|       |             | PA.5  | MFP8  | O    |                                         |
|       |             | PE.7  | MFP8  | O    |                                         |
|       | UART5_nCTS  | PB.2  | MFP7  | I    | UART5 clear to Send input pin.          |
|       |             | PH.3  | MFP4  | I    |                                         |
|       | UART5_nRTS  | PB.3  | MFP7  | O    | UART5 request to Send output pin.       |
|       |             | PH.2  | MFP4  | O    |                                         |
|       | USB_D+      | PA.14 | MFP14 | A    | USB differential signal D+.             |
|       | USB_D-      | PA.13 | MFP14 | A    | USB differential signal D-.             |
|       | USB_OTG_ID  | PA.15 | MFP14 | I    | USB_identification.                     |
| USCI0 | USB_VBUS    | PA.12 | MFP14 | P    | Power supply from USB host or HUB.      |
|       | USB_VBUS_EN | PB.15 | MFP14 | O    | USB external VBUS regulator enable pin. |
|       |             | PB.6  | MFP14 | O    |                                         |
|       | USB_VBUS_ST | PD.4  | MFP14 | I    | USB external VBUS regulator status pin. |
|       |             | PC.14 | MFP14 | I    |                                         |
|       |             | PB.7  | MFP14 | I    |                                         |
|       | USCI0_CLK   | PA.11 | MFP6  | I/O  | USCI0 clock pin.                        |
|       |             | PD.0  | MFP3  | I/O  |                                         |
|       |             | PE.2  | MFP7  | I/O  |                                         |
|       |             | PB.12 | MFP5  | I/O  |                                         |
|       | USCI0_CTL0  | PC.13 | MFP6  | I/O  | USCI0 control 0 pin.                    |
|       |             | PD.4  | MFP3  | I/O  |                                         |
|       |             | PE.6  | MFP7  | I/O  |                                         |
|       |             | PC.14 | MFP5  | I/O  |                                         |
|       | USCI0_CTL1  | PA.8  | MFP6  | I/O  | USCI0 control 1 pin.                    |
|       |             | PD.3  | MFP3  | I/O  |                                         |
|       |             | PE.5  | MFP7  | I/O  |                                         |
|       |             | PB.15 | MFP5  | I/O  |                                         |
|       | USCI0_DAT0  | PA.10 | MFP6  | I/O  | USCI0 data 0 pin.                       |
|       |             | PD.1  | MFP3  | I/O  |                                         |
|       |             | PE.3  | MFP7  | I/O  |                                         |
|       |             | PB.13 | MFP5  | I/O  |                                         |
|       | USCI0_DAT1  | PA.9  | MFP6  | I/O  | USCI0 data 1 pin.                       |
|       |             | PD.2  | MFP3  | I/O  |                                         |

| Group | Pin Name   | GPIO  | MFP   | Type | Description                                        |
|-------|------------|-------|-------|------|----------------------------------------------------|
|       |            | PE.4  | MFP7  | I/O  |                                                    |
|       |            | PB.14 | MFP5  | I/O  |                                                    |
| USCI1 | USCI1_CLK  | PB.1  | MFP8  | I/O  | USCI1 clock pin.                                   |
|       |            | PE.12 | MFP6  | I/O  |                                                    |
|       |            | PD.7  | MFP6  | I/O  |                                                    |
|       |            | PB.8  | MFP4  | I/O  |                                                    |
|       | USCI1_CTL0 | PB.5  | MFP8  | I/O  | USCI1 control 0 pin.                               |
|       |            | PE.9  | MFP6  | I/O  |                                                    |
|       |            | PD.3  | MFP6  | I/O  |                                                    |
|       |            | PB.10 | MFP4  | I/O  |                                                    |
|       | USCI1_CTL1 | PB.4  | MFP8  | I/O  | USCI1 control 1 pin.                               |
|       |            | PE.8  | MFP6  | I/O  |                                                    |
|       |            | PD.4  | MFP6  | I/O  |                                                    |
|       |            | PB.9  | MFP4  | I/O  |                                                    |
|       | USCI1_DAT0 | PB.2  | MFP8  | I/O  | USCI1 data 0 pin.                                  |
|       |            | PE.10 | MFP6  | I/O  |                                                    |
|       |            | PD.5  | MFP6  | I/O  |                                                    |
|       |            | PB.7  | MFP4  | I/O  |                                                    |
|       | USCI1_DAT1 | PB.3  | MFP8  | I/O  | USCI1 data 1 pin.                                  |
|       |            | PE.11 | MFP6  | I/O  |                                                    |
|       |            | PD.6  | MFP6  | I/O  |                                                    |
|       |            | PB.6  | MFP4  | I/O  |                                                    |
| X32   | X32_IN     | PF.5  | MFP10 | I    | External 32.768 kHz crystal input pin.             |
|       | X32_OUT    | PF.4  | MFP10 | O    | External 32.768 kHz crystal output pin.            |
| XT1   | XT1_IN     | PF.3  | MFP10 | I    | External 4~24 MHz (high speed) crystal input pin.  |
|       | XT1_OUT    | PF.2  | MFP10 | O    | External 4~24 MHz (high speed) crystal output pin. |

#### 4.2.8 M480 Multi-function Summary Table Sorted by GPIO

|      | Pin Name    | Type | MFP   | Description                                 |
|------|-------------|------|-------|---------------------------------------------|
| PA.0 | PA.0        | I/O  | MFP0  | General purpose digital I/O pin.            |
|      | SPI_MOSI    | I/O  | MFP2  | SPI_MOSI (Master Out, Slave In) pin.        |
|      | QSPI0_MOSI0 | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin. |
|      | SPI0_MOSI   | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.       |
|      | SD1_DAT0    | I/O  | MFP5  | SD/SDIO1 data line bit 0.                   |
|      | SC0_CLK     | O    | MFP6  | Smart Card 0 clock pin.                     |
|      | UART0_RXD   | I    | MFP7  | UART0 data receiver input pin.              |
|      | UART1_nRTS  | O    | MFP8  | UART1 request to Send output pin.           |
|      | I2C2_SDA    | I/O  | MFP9  | I <sup>2</sup> C2 data input/output pin.    |
|      | BPWM0_CH0   | I/O  | MFP12 | BPWM0 channel 0 output/capture input.       |
|      | EPWM0_CH5   | I/O  | MFP13 | EPWM0 channel 5 output/capture input.       |
|      | DAC0_ST     | I    | MFP15 | DAC0 external trigger input.                |
| PA.1 | PA.1        | I/O  | MFP0  | General purpose digital I/O pin.            |
|      | SPI_MISO    | I/O  | MFP2  | SPI_MISO (Master In, Slave Out) pin.        |
|      | QSPI0_MISO0 | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin. |
|      | SPI0_MISO   | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.       |
|      | SD1_DAT1    | I/O  | MFP5  | SD/SDIO1 data line bit 1.                   |
|      | SC0_DAT     | I/O  | MFP6  | Smart Card 0 data pin.                      |
|      | UART0_TXD   | O    | MFP7  | UART0 data transmitter output pin.          |
|      | UART1_nCTS  | I    | MFP8  | UART1 clear to Send input pin.              |
|      | I2C2_SCL    | I/O  | MFP9  | I <sup>2</sup> C2 clock pin.                |
|      | BPWM0_CH1   | I/O  | MFP12 | BPWM0 channel 1 output/capture input.       |
|      | EPWM0_CH4   | I/O  | MFP13 | EPWM0 channel 4 output/capture input.       |
|      | DAC1_ST     | I    | MFP15 | DAC1 external trigger input.                |
| PA.2 | PA.2        | I/O  | MFP0  | General purpose digital I/O pin.            |
|      | SPI_MCLK    | I/O  | MFP2  | SPI_MCLK serial clock pin.                  |
|      | QSPI0_CLK   | I/O  | MFP3  | Quad SPI0 serial clock pin.                 |
|      | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                      |
|      | SD1_DAT2    | I/O  | MFP5  | SD/SDIO1 data line bit 2.                   |
|      | SC0_RST     | O    | MFP6  | Smart Card 0 reset pin.                     |
|      | UART4_RXD   | I    | MFP7  | UART4 data receiver input pin.              |
|      | UART1_RXD   | I    | MFP8  | UART1 data receiver input pin.              |
|      | I2C1_SDA    | I/O  | MFP9  | I <sup>2</sup> C1 data input/output pin.    |

|      | <b>Pin Name</b> | <b>Type</b> | <b>MFP</b> | <b>Description</b>                            |
|------|-----------------|-------------|------------|-----------------------------------------------|
|      | BPWM0_CH2       | I/O         | MFP12      | BPWM0 channel 2 output/capture input.         |
|      | EPWM0_CH3       | I/O         | MFP13      | EPWM0 channel 3 output/capture input.         |
| PA.3 | PA.3            | I/O         | MFP0       | General purpose digital I/O pin.              |
|      | SPI_M_SS        | I/O         | MFP2       | SPI_M slave select pin.                       |
|      | QSPI0_SS        | I/O         | MFP3       | Quad SPI0 slave select pin.                   |
|      | SPI0_SS         | I/O         | MFP4       | SPI0 slave select pin.                        |
|      | SD1_DAT3        | I/O         | MFP5       | SD/SDIO1 data line bit 3.                     |
|      | SC0_PWR         | O           | MFP6       | Smart Card 0 power pin.                       |
|      | UART4_TXD       | O           | MFP7       | UART4 data transmitter output pin.            |
|      | UART1_TXD       | O           | MFP8       | UART1 data transmitter output pin.            |
|      | I2C1_SCL        | I/O         | MFP9       | I <sup>2</sup> C1 clock pin.                  |
|      | BPWM0_CH3       | I/O         | MFP12      | BPWM0 channel 3 output/capture input.         |
|      | EPWM0_CH2       | I/O         | MFP13      | EPWM0 channel 2 output/capture input.         |
|      | QEIO_B          | I           | MFP14      | Quadrature encoder 0 phase B input            |
| PA.4 | PA.4            | I/O         | MFP0       | General purpose digital I/O pin.              |
|      | SPI_M_D3        | I/O         | MFP2       | SPI_M data 3 pin for Quad Mode I/O.           |
|      | QSPI0_MOSI1     | I/O         | MFP3       | Quad SPI0 MOSI1 (Master Out, Slave In) pin.   |
|      | SPI0_I2SMCLK    | I/O         | MFP4       | SPI0 I <sup>2</sup> S master clock output pin |
|      | SD1_CLK         | O           | MFP5       | SD/SDIO1 clock output pin                     |
|      | SC0_nCD         | I           | MFP6       | Smart Card 0 card detect pin.                 |
|      | UART0_nRTS      | O           | MFP7       | UART0 request to Send output pin.             |
|      | UART5_RXD       | I           | MFP8       | UART5 data receiver input pin.                |
|      | I2C0_SDA        | I/O         | MFP9       | I <sup>2</sup> C0 data input/output pin.      |
|      | CAN0_RXD        | I           | MFP10      | CAN0 bus receiver input.                      |
|      | BPWM0_CH4       | I/O         | MFP12      | BPWM0 channel 4 output/capture input.         |
|      | EPWM0_CH1       | I/O         | MFP13      | EPWM0 channel 1 output/capture input.         |
| PA.5 | QEIO_A          | I           | MFP14      | Quadrature encoder 0 phase A input            |
|      | PA.5            | I/O         | MFP0       | General purpose digital I/O pin.              |
|      | SPI_M_D2        | I/O         | MFP2       | SPI_M data 2 pin for Quad Mode I/O.           |
|      | QSPI0_MISO1     | I/O         | MFP3       | Quad SPI0 MISO1 (Master In, Slave Out) pin.   |
|      | SPI1_I2SMCLK    | I/O         | MFP4       | SPI1 I <sup>2</sup> S master clock output pin |
|      | SD1_CMD         | I/O         | MFP5       | SD/SDIO1 command/response pin                 |
|      | SC2_nCD         | I           | MFP6       | Smart Card 2 card detect pin.                 |
|      | UART0_nCTS      | I           | MFP7       | UART0 clear to Send input pin.                |

|      | Pin Name        | Type | MFP   | Description                                     |
|------|-----------------|------|-------|-------------------------------------------------|
| PA.6 | UART5_TXD       | O    | MFP8  | UART5 data transmitter output pin.              |
|      | I2C0_SCL        | I/O  | MFP9  | I <sup>2</sup> C0 clock pin.                    |
|      | CAN0_TXD        | O    | MFP10 | CAN0 bus transmitter output.                    |
|      | BPWM0_CH5       | I/O  | MFP12 | BPWM0 channel 5 output/capture input.           |
|      | EPWM0_CH0       | I/O  | MFP13 | EPWM0 channel 0 output/capture input.           |
|      | QEI0_INDEX      | I    | MFP14 | Quadrature encoder 0 index input                |
| PA.7 | PA.6            | I/O  | MFP0  | General purpose digital I/O pin.                |
|      | EBI_AD6         | I/O  | MFP2  | EBI address/data bus bit 6.                     |
|      | EMAC_RMII_RXERR | I    | MFP3  | EMAC RMII Receive Data Error input pin.         |
|      | SPI1_SS         | I/O  | MFP4  | SPI1 slave select pin.                          |
|      | SD1_nCD         | I    | MFP5  | SD/SDIO1 card detect input pin                  |
|      | SC2_CLK         | O    | MFP6  | Smart Card 2 clock pin.                         |
|      | UART0_RXD       | I    | MFP7  | UART0 data receiver input pin.                  |
|      | I2C1_SDA        | I/O  | MFP8  | I <sup>2</sup> C1 data input/output pin.        |
|      | EPWM1_CH5       | I/O  | MFP11 | EPWM1 channel 5 output/capture input.           |
|      | BPWM1_CH3       | I/O  | MFP12 | BPWM1 channel 3 output/capture input.           |
|      | ACMP1_WLAT      | I    | MFP13 | Analog comparator 1 window latch input pin      |
|      | TM3             | I/O  | MFP14 | Timer3 event counter input/toggle output pin.   |
| PA.8 | INT0            | I    | MFP15 | External interrupt 0 input pin.                 |
|      | PA.7            | I/O  | MFP0  | General purpose digital I/O pin.                |
|      | EBI_AD7         | I/O  | MFP2  | EBI address/data bus bit 7.                     |
|      | EMAC_RMII_CRSDV | I    | MFP3  | EMAC RMII Carrier Sense/Receive Data input pin. |
|      | SPI1_CLK        | I/O  | MFP4  | SPI1 serial clock pin.                          |
|      | SC2_DAT         | I/O  | MFP6  | Smart Card 2 data pin.                          |
|      | UART0_TXD       | O    | MFP7  | UART0 data transmitter output pin.              |
|      | I2C1_SCL        | I/O  | MFP8  | I <sup>2</sup> C1 clock pin.                    |
|      | EPWM1_CH4       | I/O  | MFP11 | EPWM1 channel 4 output/capture input.           |
|      | BPWM1_CH2       | I/O  | MFP12 | BPWM1 channel 2 output/capture input.           |
|      | ACMP0_WLAT      | I    | MFP13 | Analog comparator 0 window latch input pin      |
|      | TM2             | I/O  | MFP14 | Timer2 event counter input/toggle output pin.   |
| PA.8 | INT1            | I    | MFP15 | External interrupt 1 input pin.                 |
|      | PA.8            | I/O  | MFP0  | General purpose digital I/O pin.                |
|      | OPA1_P          | A    | MFP1  | Operational amplifier 1 positive input pin.     |
|      | EBI_ALE         | O    | MFP2  | EBI address latch enable output pin.            |

|       | Pin Name   | Type | MFP   | Description                                      |
|-------|------------|------|-------|--------------------------------------------------|
| PA.9  | SC2_CLK    | O    | MFP3  | Smart Card 2 clock pin.                          |
|       | SPI2_MOSI  | I/O  | MFP4  | SPI2 MOSI (Master Out, Slave In) pin.            |
|       | SD1_DAT0   | I/O  | MFP5  | SD/SDIO1 data line bit 0.                        |
|       | USCI0_CTL1 | I/O  | MFP6  | USCI0 control 1 pin.                             |
|       | UART1_RXD  | I    | MFP7  | UART1 data receiver input pin.                   |
|       | BPWM0_CH3  | I/O  | MFP9  | BPWM0 channel 3 output/capture input.            |
|       | QE1_B      | I    | MFP10 | Quadrature encoder 1 phase B input               |
|       | ECAP0_IC2  | I    | MFP11 | Enhanced capture unit 0 input 2 pin.             |
|       | TM3_EXT    | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
|       | INT4       | I    | MFP15 | External interrupt 4 input pin.                  |
| PA.10 | PA.9       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | OPA1_N     | A    | MFP1  | Operational amplifier 1 negative input pin.      |
|       | EBI_MCLK   | O    | MFP2  | EBI external clock output pin.                   |
|       | SC2_DAT    | I/O  | MFP3  | Smart Card 2 data pin.                           |
|       | SPI2_MISO  | I/O  | MFP4  | SPI2 MISO (Master In, Slave Out) pin.            |
|       | SD1_DAT1   | I/O  | MFP5  | SD/SDIO1 data line bit 1.                        |
|       | USCI0_DAT1 | I/O  | MFP6  | USCI0 data 1 pin.                                |
|       | UART1_TXD  | O    | MFP7  | UART1 data transmitter output pin.               |
|       | BPWM0_CH2  | I/O  | MFP9  | BPWM0 channel 2 output/capture input.            |
|       | QE1_A      | I    | MFP10 | Quadrature encoder 1 phase A input               |
| PA.11 | ECAP0_IC1  | I    | MFP11 | Enhanced capture unit 0 input 1 pin.             |
|       | TM2_EXT    | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
|       | PA.10      | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | ACMP1_P0   | A    | MFP1  | Analog comparator 1 positive input 0 pin.        |
|       | OPA1_O     | A    | MFP1  | Operational amplifier 1 output pin.              |
|       | EBI_nWR    | O    | MFP2  | EBI write enable output pin.                     |
|       | SC2_RST    | O    | MFP3  | Smart Card 2 reset pin.                          |
|       | SPI2_CLK   | I/O  | MFP4  | SPI2 serial clock pin.                           |
|       | SD1_DAT2   | I/O  | MFP5  | SD/SDIO1 data line bit 2.                        |
|       | USCI0_DAT0 | I/O  | MFP6  | USCI0 data 0 pin.                                |
| PA.12 | I2C2_SDA   | I/O  | MFP7  | I <sup>2</sup> C2 data input/output pin.         |
|       | BPWM0_CH1  | I/O  | MFP9  | BPWM0 channel 1 output/capture input.            |
|       | QE1_INDEX  | I    | MFP10 | Quadrature encoder 1 index input                 |
|       | ECAP0_IC0  | I    | MFP11 | Enhanced capture unit 0 input 0 pin.             |

|       | Pin Name       | Type | MFP   | Description                                      |
|-------|----------------|------|-------|--------------------------------------------------|
|       | TM1_EXT        | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
|       | DAC0_ST        | I    | MFP14 | DAC0 external trigger input.                     |
| PA.11 | PA.11          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | ACMP0_P0       | A    | MFP1  | Analog comparator 0 positive input 0 pin.        |
|       | EBI_nRD        | O    | MFP2  | EBI read enable output pin.                      |
|       | SC2_PWR        | O    | MFP3  | Smart Card 2 power pin.                          |
|       | SPI2_SS        | I/O  | MFP4  | SPI2 slave select pin.                           |
|       | SD1_DAT3       | I/O  | MFP5  | SD/SDIO1 data line bit 3.                        |
|       | USCI0_CLK      | I/O  | MFP6  | USCI0 clock pin.                                 |
|       | I2C2_SCL       | I/O  | MFP7  | I <sup>2</sup> C2 clock pin.                     |
|       | BPWM0_CH0      | I/O  | MFP9  | BPWM0 channel 0 output/capture input.            |
|       | EPWM0_SYNC_OUT | O    | MFP10 | EPWM0 counter synchronous trigger output pin.    |
|       | TM0_EXT        | I/O  | MFP13 | Timer0 external capture input/toggle output pin. |
|       | DAC1_ST        | I    | MFP14 | DAC1 external trigger input.                     |
| PA.12 | PA.12          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | I2S0_BCLK      | O    | MFP2  | I <sup>2</sup> S0 bit clock output pin.          |
|       | UART4_TXD      | O    | MFP3  | UART4 data transmitter output pin.               |
|       | I2C1_SCL       | I/O  | MFP4  | I <sup>2</sup> C1 clock pin.                     |
|       | SPI2_SS        | I/O  | MFP5  | SPI2 slave select pin.                           |
|       | CAN0_TXD       | O    | MFP6  | CAN0 bus transmitter output.                     |
|       | SC2_PWR        | O    | MFP7  | Smart Card 2 power pin.                          |
|       | BPWM1_CH2      | I/O  | MFP11 | BPWM1 channel 2 output/capture input.            |
|       | QEI1_INDEX     | I    | MFP12 | Quadrature encoder 1 index input                 |
|       | USB_VBUS       | P    | MFP14 | Power supply from USB host or HUB.               |
| PA.13 | PA.13          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | I2S0_MCLK      | O    | MFP2  | I <sup>2</sup> S0 master clock output pin.       |
|       | UART4_RXD      | I    | MFP3  | UART4 data receiver input pin.                   |
|       | I2C1_SDA       | I/O  | MFP4  | I <sup>2</sup> C1 data input/output pin.         |
|       | SPI2_CLK       | I/O  | MFP5  | SPI2 serial clock pin.                           |
|       | CAN0_RXD       | I    | MFP6  | CAN0 bus receiver input.                         |
|       | SC2_RST        | O    | MFP7  | Smart Card 2 reset pin.                          |
|       | BPWM1_CH3      | I/O  | MFP11 | BPWM1 channel 3 output/capture input.            |
|       | QEI1_A         | I    | MFP12 | Quadrature encoder 1 phase A input               |
|       | USB_D-         | A    | MFP14 | USB differential signal D-.                      |

|       | Pin Name      | Type | MFP   | Description                                   |
|-------|---------------|------|-------|-----------------------------------------------|
| PA.14 | PA.14         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | I2S0_DI       | I    | MFP2  | I <sup>2</sup> S0 data input pin.             |
|       | UART0_TXD     | O    | MFP3  | UART0 data transmitter output pin.            |
|       | SPI2_MISO     | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.         |
|       | I2C2_SCL      | I/O  | MFP6  | I <sup>2</sup> C2 clock pin.                  |
|       | SC2_DAT       | I/O  | MFP7  | Smart Card 2 data pin.                        |
|       | BPWM1_CH4     | I/O  | MFP11 | BPWM1 channel 4 output/capture input.         |
|       | QEI1_B        | I    | MFP12 | Quadrature encoder 1 phase B input            |
|       | USB_D+        | A    | MFP14 | USB differential signal D+.                   |
| PA.15 | PA.15         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | I2S0_DO       | O    | MFP2  | I <sup>2</sup> S0 data output pin.            |
|       | UART0_RXD     | I    | MFP3  | UART0 data receiver input pin.                |
|       | SPI2_MOSI     | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.         |
|       | I2C2_SDA      | I/O  | MFP6  | I <sup>2</sup> C2 data input/output pin.      |
|       | SC2_CLK       | O    | MFP7  | Smart Card 2 clock pin.                       |
|       | BPWM1_CH5     | I/O  | MFP11 | BPWM1 channel 5 output/capture input.         |
|       | EPWM0_SYNC_IN | I    | MFP12 | EPWM0 counter synchronous trigger input pin.  |
|       | USB_OTG_ID    | I    | MFP14 | USB_ identification.                          |
| PB.0  | PB.0          | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EADC0_CH0     | A    | MFP1  | EADC0 channel 0 analog input.                 |
|       | OPA0_P        | A    | MFP1  | Operational amplifier 0 positive input pin.   |
|       | EBI_ADR9      | O    | MFP2  | EBI address bus bit 9.                        |
|       | SD0_CMD       | I/O  | MFP3  | SD/SDIO0 command/response pin                 |
|       | UART2_RXD     | I    | MFP7  | UART2 data receiver input pin.                |
|       | SPI0_I2SMCLK  | I/O  | MFP8  | SPI0 I <sup>2</sup> S master clock output pin |
|       | I2C1_SDA      | I/O  | MFP9  | I <sup>2</sup> C1 data input/output pin.      |
|       | EPWM0_CH5     | I/O  | MFP11 | EPWM0 channel 5 output/capture input.         |
|       | EPWM1_CH5     | I/O  | MFP12 | EPWM1 channel 5 output/capture input.         |
| PB.1  | EPWM0_BRAKE1  | I    | MFP13 | EPWM0 Brake 1 input pin.                      |
|       | PB.1          | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EADC0_CH1     | A    | MFP1  | EADC0 channel 1 analog input.                 |
|       | OPA0_N        | A    | MFP1  | Operational amplifier 0 negative input pin.   |
|       | EBI_ADR8      | O    | MFP2  | EBI address bus bit 8.                        |
|       | SD0_CLK       | O    | MFP3  | SD/SDIO0 clock output pin                     |

|      | Pin Name               | Type | MFP   | Description                                            |
|------|------------------------|------|-------|--------------------------------------------------------|
| PB.2 | EMAC_RMII_RXERR        | I    | MFP4  | EMAC RMII Receive Data Error input pin.                |
|      | SPI1_I2SMCLK           | I/O  | MFP5  | SPI1 I <sup>2</sup> S master clock output pin          |
|      | SPI3_I2SMCLK           | I/O  | MFP6  | SPI3 I <sup>2</sup> S master clock output pin          |
|      | UART2_TXD              | O    | MFP7  | UART2 data transmitter output pin.                     |
|      | USCI1_CLK              | I/O  | MFP8  | USCI1 clock pin.                                       |
|      | I <sup>2</sup> C1_SCL  | I/O  | MFP9  | I <sup>2</sup> C1 clock pin.                           |
|      | I <sup>2</sup> S0_LRCK | O    | MFP10 | I <sup>2</sup> S0 left right channel clock output pin. |
|      | EPWM0_CH4              | I/O  | MFP11 | EPWM0 channel 4 output/capture input.                  |
|      | EPWM1_CH4              | I/O  | MFP12 | EPWM1 channel 4 output/capture input.                  |
|      | EPWM0_BRAKE0           | I    | MFP13 | EPWM0 Brake 0 input pin.                               |
|      | PB.2                   | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EADC0_CH2              | A    | MFP1  | EADC0 channel 2 analog input.                          |
|      | ACMP0_P1               | A    | MFP1  | Analog comparator 0 positive input 1 pin.              |
|      | OPA0_O                 | A    | MFP1  | Operational amplifier 0 output pin.                    |
| PB.3 | EBI_ADR3               | O    | MFP2  | EBI address bus bit 3.                                 |
|      | SD0_DAT0               | I/O  | MFP3  | SD/SDIO0 data line bit 0.                              |
|      | EMAC_RMII_CRSDV        | I    | MFP4  | EMAC RMII Carrier Sense/Receive Data input pin.        |
|      | SPI1_SS                | I/O  | MFP5  | SPI1 slave select pin.                                 |
|      | UART1_RXD              | I    | MFP6  | UART1 data receiver input pin.                         |
|      | UART5_nCTS             | I    | MFP7  | UART5 clear to Send input pin.                         |
|      | USCI1_DAT0             | I/O  | MFP8  | USCI1 data 0 pin.                                      |
|      | SC0_PWR                | O    | MFP9  | Smart Card 0 power pin.                                |
|      | I <sup>2</sup> S0_DO   | O    | MFP10 | I <sup>2</sup> S0 data output pin.                     |
|      | EPWM0_CH3              | I/O  | MFP11 | EPWM0 channel 3 output/capture input.                  |
|      | TM3                    | I/O  | MFP14 | Timer3 event counter input/toggle output pin.          |
|      | INT3                   | I    | MFP15 | External interrupt 3 input pin.                        |
|      | PB.3                   | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EADC0_CH3              | A    | MFP1  | EADC0 channel 3 analog input.                          |
|      | ACMP0_N                | A    | MFP1  | Analog comparator 0 negative input pin.                |
|      | EBI_ADR2               | O    | MFP2  | EBI address bus bit 2.                                 |
|      | SD0_DAT1               | I/O  | MFP3  | SD/SDIO0 data line bit 1.                              |
|      | EMAC_RMII_RXD1         | I    | MFP4  | EMAC RMII Receive Data bus bit 1.                      |
|      | SPI1_CLK               | I/O  | MFP5  | SPI1 serial clock pin.                                 |
|      | UART1_TXD              | O    | MFP6  | UART1 data transmitter output pin.                     |

|      | Pin Name         | Type | MFP   | Description                                   |
|------|------------------|------|-------|-----------------------------------------------|
| PB.4 | UART5_nRTS       | O    | MFP7  | UART5 request to Send output pin.             |
|      | USCI1_DAT1       | I/O  | MFP8  | USCI1 data 1 pin.                             |
|      | SC0_RST          | O    | MFP9  | Smart Card 0 reset pin.                       |
|      | I2S0_DI          | I    | MFP10 | I <sup>2</sup> S0 data input pin.             |
|      | EPWM0_CH2        | I/O  | MFP11 | EPWM0 channel 2 output/capture input.         |
|      | TM2              | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
|      | INT2             | I    | MFP15 | External interrupt 2 input pin.               |
| PB.4 | PB.4             | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EADC0_CH4        | A    | MFP1  | EADC0 channel 4 analog input.                 |
|      | ACMP1_P1         | A    | MFP1  | Analog comparator 1 positive input 1 pin.     |
|      | EBI_ADR1         | O    | MFP2  | EBI address bus bit 1.                        |
|      | SD0_DAT2         | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|      | EMAC_RMII_RXD0   | I    | MFP4  | EMAC RMII Receive Data bus bit 0.             |
|      | SPI1_MOSI        | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.         |
|      | I2C0_SDA         | I/O  | MFP6  | I <sup>2</sup> C0 data input/output pin.      |
|      | UART5_RXD        | I    | MFP7  | UART5 data receiver input pin.                |
|      | USCI1_CTL1       | I/O  | MFP8  | USCI1 control 1 pin.                          |
|      | SC0_DAT          | I/O  | MFP9  | Smart Card 0 data pin.                        |
|      | I2S0_MCLK        | O    | MFP10 | I <sup>2</sup> S0 master clock output pin.    |
|      | EPWM0_CH1        | I/O  | MFP11 | EPWM0 channel 1 output/capture input.         |
|      | TM1              | I/O  | MFP14 | Timer1 event counter input/toggle output pin. |
|      | INT1             | I    | MFP15 | External interrupt 1 input pin.               |
| PB.5 | PB.5             | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EADC0_CH5        | A    | MFP1  | EADC0 channel 5 analog input.                 |
|      | ACMP1_N          | A    | MFP1  | Analog comparator 1 negative input pin.       |
|      | EBI_ADR0         | O    | MFP2  | EBI address bus bit 0.                        |
|      | SD0_DAT3         | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|      | EMAC_RMII_REFCLK | I    | MFP4  | EMAC RMII reference clock input pin.          |
|      | SPI1_MISO        | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.         |
|      | I2C0_SCL         | I/O  | MFP6  | I <sup>2</sup> C0 clock pin.                  |
|      | UART5_TXD        | O    | MFP7  | UART5 data transmitter output pin.            |
|      | USCI1_CTL0       | I/O  | MFP8  | USCI1 control 0 pin.                          |
|      | SC0_CLK          | O    | MFP9  | Smart Card 0 clock pin.                       |
|      | I2S0_BCLK        | O    | MFP10 | I <sup>2</sup> S0 bit clock output pin.       |

|      | Pin Name       | Type | MFP   | Description                                   |
|------|----------------|------|-------|-----------------------------------------------|
|      | EPWM0_CH0      | I/O  | MFP11 | EPWM0 channel 0 output/capture input.         |
|      | TMO            | I/O  | MFP14 | Timer0 event counter input/toggle output pin. |
|      | INT0           | I    | MFP15 | External interrupt 0 input pin.               |
| PB.6 | PB.6           | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EADC0_CH6      | A    | MFP1  | EADC0 channel 6 analog input.                 |
|      | EBI_nWRH       | O    | MFP2  | EBI high byte write enable output pin         |
|      | EMAC_PPS       | O    | MFP3  | EMAC Pulse Per Second output pin.             |
|      | USCI1_DAT1     | I/O  | MFP4  | USCI1 data 1 pin.                             |
|      | CAN1_RXD       | I    | MFP5  | CAN1 bus receiver input.                      |
|      | UART1_RXD      | I    | MFP6  | UART1 data receiver input pin.                |
|      | SD1_CLK        | O    | MFP7  | SD/SDIO1 clock output pin                     |
|      | EBI_nCS1       | O    | MFP8  | EBI chip select 1 output pin.                 |
|      | BPWM1_CH5      | I/O  | MFP10 | BPWM1 channel 5 output/capture input.         |
|      | EPWM1_BRAKE1   | I    | MFP11 | EPWM1 Brake 1 input pin.                      |
|      | EPWM1_CH5      | I/O  | MFP12 | EPWM1 channel 5 output/capture input.         |
|      | INT4           | I    | MFP13 | External interrupt 4 input pin.               |
|      | USB_VBUS_EN    | O    | MFP14 | USB external VBUS regulator enable pin.       |
|      | ACMP1_O        | O    | MFP15 | Analog comparator 1 output pin.               |
| PB.7 | PB.7           | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EADC0_CH7      | A    | MFP1  | EADC0 channel 7 analog input.                 |
|      | EBI_nWRL       | O    | MFP2  | EBI low byte write enable output pin.         |
|      | EMAC_RMII_TXEN | O    | MFP3  | EMAC RMII Transmit Enable output pin.         |
|      | USCI1_DAT0     | I/O  | MFP4  | USCI1 data 0 pin.                             |
|      | CAN1_TXD       | O    | MFP5  | CAN1 bus transmitter output.                  |
|      | UART1_TXD      | O    | MFP6  | UART1 data transmitter output pin.            |
|      | SD1_CMD        | I/O  | MFP7  | SD/SDIO1 command/response pin                 |
|      | EBI_nCS0       | O    | MFP8  | EBI chip select 0 output pin.                 |
|      | BPWM1_CH4      | I/O  | MFP10 | BPWM1 channel 4 output/capture input.         |
|      | EPWM1_BRAKE0   | I    | MFP11 | EPWM1 Brake 0 input pin.                      |
|      | EPWM1_CH4      | I/O  | MFP12 | EPWM1 channel 4 output/capture input.         |
|      | INT5           | I    | MFP13 | External interrupt 5 input pin.               |
|      | USB_VBUS_ST    | I    | MFP14 | USB external VBUS regulator status pin.       |
|      | ACMP0_O        | O    | MFP15 | Analog comparator 0 output pin.               |
| PB.8 | PB.8           | I/O  | MFP0  | General purpose digital I/O pin.              |

|       | Pin Name       | Type | MFP   | Description                                            |
|-------|----------------|------|-------|--------------------------------------------------------|
| PB.9  | EADC0_CH8      | A    | MFP1  | EADC0 channel 8 analog input.                          |
|       | EBI_ADR19      | O    | MFP2  | EBI address bus bit 19.                                |
|       | EMAC_RMII_TXD1 | O    | MFP3  | EMAC RMII Transmit Data bus bit 1.                     |
|       | USCI1_CLK      | I/O  | MFP4  | USCI1 clock pin.                                       |
|       | UART0_RXD      | I    | MFP5  | UART0 data receiver input pin.                         |
|       | UART1_nRTS     | O    | MFP6  | UART1 request to Send output pin.                      |
|       | I2C1_SMBSUS    | O    | MFP7  | I <sup>2</sup> C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|       | BPWM1_CH3      | I/O  | MFP10 | BPWM1 channel 3 output/capture input.                  |
|       | SPI3_MOSI      | I/O  | MFP11 | SPI3 MOSI (Master Out, Slave In) pin.                  |
|       | INT6           | I    | MFP13 | External interrupt 6 input pin.                        |
| PB.10 | PB.9           | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EADC0_CH9      | A    | MFP1  | EADC0 channel 9 analog input.                          |
|       | EBI_ADR18      | O    | MFP2  | EBI address bus bit 18.                                |
|       | EMAC_RMII_TXD0 | O    | MFP3  | EMAC RMII Transmit Data bus bit 0.                     |
|       | USCI1_CTL1     | I/O  | MFP4  | USCI1 control 1 pin.                                   |
|       | UART0_TXD      | O    | MFP5  | UART0 data transmitter output pin.                     |
|       | UART1_nCTS     | I    | MFP6  | UART1 clear to Send input pin.                         |
|       | I2C1_SMBAL     | O    | MFP7  | I <sup>2</sup> C1 SMBus SMBALTER pin                   |
|       | BPWM1_CH2      | I/O  | MFP10 | BPWM1 channel 2 output/capture input.                  |
|       | SPI3_MISO      | I/O  | MFP11 | SPI3 MISO (Master In, Slave Out) pin.                  |
| PB.11 | INT7           | I    | MFP13 | External interrupt 7 input pin.                        |
| PB.10 | PB.10          | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EADC0_CH10     | A    | MFP1  | EADC0 channel 10 analog input.                         |
|       | EBI_ADR17      | O    | MFP2  | EBI address bus bit 17.                                |
|       | EMAC_RMII_MDIO | I/O  | MFP3  | EMAC RMII PHY Management Data pin.                     |
|       | USCI1_CTL0     | I/O  | MFP4  | USCI1 control 0 pin.                                   |
|       | UART0_nRTS     | O    | MFP5  | UART0 request to Send output pin.                      |
|       | UART4_RXD      | I    | MFP6  | UART4 data receiver input pin.                         |
|       | I2C1_SDA       | I/O  | MFP7  | I <sup>2</sup> C1 data input/output pin.               |
|       | CAN0_RXD       | I    | MFP8  | CAN0 bus receiver input.                               |
|       | BPWM1_CH1      | I/O  | MFP10 | BPWM1 channel 1 output/capture input.                  |
|       | SPI3_SS        | I/O  | MFP11 | SPI3 slave select pin.                                 |
|       | HSUSB_VBUS_EN  | O    | MFP14 | HSUSB external VBUS regulator enable pin.              |
| PB.11 | PB.11          | I/O  | MFP0  | General purpose digital I/O pin.                       |

|       | Pin Name      | Type | MFP   | Description                                      |
|-------|---------------|------|-------|--------------------------------------------------|
| PB.12 | EADC0_CH11    | A    | MFP1  | EADC0 channel 11 analog input.                   |
|       | EBI_ADR16     | O    | MFP2  | EBI address bus bit 16.                          |
|       | EMAC_RMII_MDC | O    | MFP3  | EMAC RMII PHY Management Clock output pin.       |
|       | UART0_nCTS    | I    | MFP5  | UART0 clear to Send input pin.                   |
|       | UART4_TXD     | O    | MFP6  | UART4 data transmitter output pin.               |
|       | I2C1_SCL      | I/O  | MFP7  | I <sup>2</sup> C1 clock pin.                     |
|       | CAN0_TXD      | O    | MFP8  | CAN0 bus transmitter output.                     |
|       | SPI0_I2SMCLK  | I/O  | MFP9  | SPI0 I <sup>2</sup> S master clock output pin    |
|       | BPWM1_CH0     | I/O  | MFP10 | BPWM1 channel 0 output/capture input.            |
|       | SPI3_CLK      | I/O  | MFP11 | SPI3 serial clock pin.                           |
|       | HSUSB_VBUS_ST | I    | MFP14 | HSUSB external VBUS regulator status pin.        |
|       | PB.12         | I/O  | MFP0  | General purpose digital I/O pin.                 |
| PB.13 | EADC0_CH12    | A    | MFP1  | EADC0 channel 12 analog input.                   |
|       | DAC0_OUT      | A    | MFP1  | DAC0 channel analog output.                      |
|       | ACMP0_P2      | A    | MFP1  | Analog comparator 0 positive input 2 pin.        |
|       | ACMP1_P2      | A    | MFP1  | Analog comparator 1 positive input 2 pin.        |
|       | EBI_AD15      | I/O  | MFP2  | EBI address/data bus bit 15.                     |
|       | SC1_CLK       | O    | MFP3  | Smart Card 1 clock pin.                          |
|       | SPI0_MOSI     | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.            |
|       | USCI0_CLK     | I/O  | MFP5  | USCI0 clock pin.                                 |
|       | UART0_RXD     | I    | MFP6  | UART0 data receiver input pin.                   |
|       | UART3_nCTS    | I    | MFP7  | UART3 clear to Send input pin.                   |
|       | I2C2_SDA      | I/O  | MFP8  | I <sup>2</sup> C2 data input/output pin.         |
|       | SD0_nCD       | I    | MFP9  | SD/SDIO0 card detect input pin                   |
| PB.14 | EPWM1_CH3     | I/O  | MFP11 | EPWM1 channel 3 output/capture input.            |
|       | TM3_EXT       | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
|       | PB.13         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | EADC0_CH13    | A    | MFP1  | EADC0 channel 13 analog input.                   |
| PB.14 | DAC1_OUT      | A    | MFP1  | DAC1 channel analog output.                      |
|       | ACMP0_P3      | A    | MFP1  | Analog comparator 0 positive input 3 pin.        |
|       | ACMP1_P3      | A    | MFP1  | Analog comparator 1 positive input 3 pin.        |
|       | EBI_AD14      | I/O  | MFP2  | EBI address/data bus bit 14.                     |
| PB.15 | SC1_DAT       | I/O  | MFP3  | Smart Card 1 data pin.                           |
|       | SPI0_MISO     | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.            |

|       | Pin Name    | Type | MFP   | Description                                           |
|-------|-------------|------|-------|-------------------------------------------------------|
| PB.14 | USCI0_DAT0  | I/O  | MFP5  | USCI0 data 0 pin.                                     |
|       | UART0_TXD   | O    | MFP6  | UART0 data transmitter output pin.                    |
|       | UART3_nRTS  | O    | MFP7  | UART3 request to Send output pin.                     |
|       | I2C2_SCL    | I/O  | MFP8  | I <sup>2</sup> C clock pin.                           |
|       | EPWM1_CH2   | I/O  | MFP11 | EPWM1 channel 2 output/capture input.                 |
|       | TM2_EXT     | I/O  | MFP13 | Timer2 external capture input/toggle output pin.      |
| PB.15 | PB.14       | I/O  | MFP0  | General purpose digital I/O pin.                      |
|       | EADC0_CH14  | A    | MFP1  | EADC0 channel 14 analog input.                        |
|       | EBI_AD13    | I/O  | MFP2  | EBI address/data bus bit 13.                          |
|       | SC1_RST     | O    | MFP3  | Smart Card 1 reset pin.                               |
|       | SPI0_CLK    | I/O  | MFP4  | SPI0 serial clock pin.                                |
|       | USCI0_DAT1  | I/O  | MFP5  | USCI0 data 1 pin.                                     |
|       | UART0_nRTS  | O    | MFP6  | UART0 request to Send output pin.                     |
|       | UART3_RXD   | I    | MFP7  | UART3 data receiver input pin.                        |
|       | I2C2_SMBSUS | O    | MFP8  | I <sup>2</sup> C SMBus SMBSUS pin (PMBus CONTROL pin) |
|       | EPWM1_CH1   | I/O  | MFP11 | EPWM1 channel 1 output/capture input.                 |
|       | TM1_EXT     | I/O  | MFP13 | Timer1 external capture input/toggle output pin.      |
|       | CLKO        | O    | MFP14 | Clock Out                                             |
| PC.0  | PB.15       | I/O  | MFP0  | General purpose digital I/O pin.                      |
|       | EADC0_CH15  | A    | MFP1  | EADC0 channel 15 analog input.                        |
|       | EBI_AD12    | I/O  | MFP2  | EBI address/data bus bit 12.                          |
|       | SC1_PWR     | O    | MFP3  | Smart Card 1 power pin.                               |
|       | SPI0_SS     | I/O  | MFP4  | SPI0 slave select pin.                                |
|       | USCI0_CTL1  | I/O  | MFP5  | USCI0 control 1 pin.                                  |
|       | UART0_nCTS  | I    | MFP6  | UART0 clear to Send input pin.                        |
|       | UART3_TXD   | O    | MFP7  | UART3 data transmitter output pin.                    |
|       | I2C2_SMBAL  | O    | MFP8  | I <sup>2</sup> C SMBus SMBALTER pin                   |
|       | EPWM1_CH0   | I/O  | MFP11 | EPWM1 channel 0 output/capture input.                 |
|       | TM0_EXT     | I/O  | MFP13 | Timer0 external capture input/toggle output pin.      |
|       | USB_VBUS_EN | O    | MFP14 | USB external VBUS regulator enable pin.               |

|      | Pin Name    | Type | MFP   | Description                                            |
|------|-------------|------|-------|--------------------------------------------------------|
| PC.1 | QSPI0_MOSI0 | I/O  | MFP4  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.            |
|      | SC1_CLK     | O    | MFP5  | Smart Card 1 clock pin.                                |
|      | I2S0_LRCK   | O    | MFP6  | I <sup>2</sup> S0 left right channel clock output pin. |
|      | SPI1_SS     | I/O  | MFP7  | SPI1 slave select pin.                                 |
|      | UART2_RXD   | I    | MFP8  | UART2 data receiver input pin.                         |
|      | I2C0_SDA    | I/O  | MFP9  | I <sup>2</sup> C0 data input/output pin.               |
|      | EPWM1_CH5   | I/O  | MFP12 | EPWM1 channel 5 output/capture input.                  |
|      | ACMP1_O     | O    | MFP14 | Analog comparator 1 output pin.                        |
|      | PC.1        | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_AD1     | I/O  | MFP2  | EBI address/data bus bit 1.                            |
| PC.2 | SPIM_MISO   | I/O  | MFP3  | SPIM MISO (Master In, Slave Out) pin.                  |
|      | QSPI0_MISO0 | I/O  | MFP4  | Quad SPI0 MISO0 (Master In, Slave Out) pin.            |
|      | SC1_DAT     | I/O  | MFP5  | Smart Card 1 data pin.                                 |
|      | I2S0_DO     | O    | MFP6  | I <sup>2</sup> S0 data output pin.                     |
|      | SPI1_CLK    | I/O  | MFP7  | SPI1 serial clock pin.                                 |
|      | UART2_TXD   | O    | MFP8  | UART2 data transmitter output pin.                     |
|      | I2C0_SCL    | I/O  | MFP9  | I <sup>2</sup> C0 clock pin.                           |
|      | EPWM1_CH4   | I/O  | MFP12 | EPWM1 channel 4 output/capture input.                  |
|      | ACMP0_O     | O    | MFP14 | Analog comparator 0 output pin.                        |
|      | PC.2        | I/O  | MFP0  | General purpose digital I/O pin.                       |
| PC.3 | EBI_AD2     | I/O  | MFP2  | EBI address/data bus bit 2.                            |
|      | SPIM_CLK    | I/O  | MFP3  | SPIM serial clock pin.                                 |
|      | QSPI0_CLK   | I/O  | MFP4  | Quad SPI0 serial clock pin.                            |
|      | SC1_RST     | O    | MFP5  | Smart Card 1 reset pin.                                |
|      | I2S0_DI     | I    | MFP6  | I <sup>2</sup> S0 data input pin.                      |
|      | SPI1_MOSI   | I/O  | MFP7  | SPI1 MOSI (Master Out, Slave In) pin.                  |
|      | UART2_nCTS  | I    | MFP8  | UART2 clear to Send input pin.                         |
|      | I2C0_SMBSUS | O    | MFP9  | I <sup>2</sup> C0 SMBus SMBSUS pin (PMBus CONTROL pin) |
|      | CAN1_RXD    | I    | MFP10 | CAN1 bus receiver input.                               |
|      | UART3_RXD   | I    | MFP11 | UART3 data receiver input pin.                         |
| PC.3 | EPWM1_CH3   | I/O  | MFP12 | EPWM1 channel 3 output/capture input.                  |
|      | PC.3        | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_AD3     | I/O  | MFP2  | EBI address/data bus bit 3.                            |
|      | SPIM_SS     | I/O  | MFP3  | SPIM slave select pin.                                 |

|      | Pin Name     | Type | MFP   | Description                                   |
|------|--------------|------|-------|-----------------------------------------------|
| PC.4 | QSPI0_SS     | I/O  | MFP4  | Quad SPI0 slave select pin.                   |
|      | SC1_PWR      | O    | MFP5  | Smart Card 1 power pin.                       |
|      | I2S0_MCLK    | O    | MFP6  | I <sup>2</sup> S0 master clock output pin.    |
|      | SPI1_MISO    | I/O  | MFP7  | SPI1 MISO (Master In, Slave Out) pin.         |
|      | UART2_nRTS   | O    | MFP8  | UART2 request to Send output pin.             |
|      | I2C0_SMBAL   | O    | MFP9  | I <sup>2</sup> C0 SMBus SMBALTER pin          |
|      | CAN1_TXD     | O    | MFP10 | CAN1 bus transmitter output.                  |
|      | UART3_TXD    | O    | MFP11 | UART3 data transmitter output pin.            |
|      | EPWM1_CH2    | I/O  | MFP12 | EPWM1 channel 2 output/capture input.         |
|      | PC.4         | I/O  | MFP0  | General purpose digital I/O pin.              |
| PC.5 | EBI_AD4      | I/O  | MFP2  | EBI address/data bus bit 4.                   |
|      | SPIM_D3      | I/O  | MFP3  | SPIM data 3 pin for Quad Mode I/O.            |
|      | QSPI0_MOSI1  | I/O  | MFP4  | Quad SPI0 MOSI1 (Master Out, Slave In) pin.   |
|      | SC1_nCD      | I    | MFP5  | Smart Card 1 card detect pin.                 |
|      | I2S0_BCLK    | O    | MFP6  | I <sup>2</sup> S0 bit clock output pin.       |
|      | SPI1_I2SMCLK | I/O  | MFP7  | SPI1 I <sup>2</sup> S master clock output pin |
|      | UART2_RXD    | I    | MFP8  | UART2 data receiver input pin.                |
|      | I2C1_SDA     | I/O  | MFP9  | I <sup>2</sup> C1 data input/output pin.      |
|      | CAN0_RXD     | I    | MFP10 | CAN0 bus receiver input.                      |
|      | UART4_RXD    | I    | MFP11 | UART4 data receiver input pin.                |
| PC.6 | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.         |
|      | PC.5         | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EBI_AD5      | I/O  | MFP2  | EBI address/data bus bit 5.                   |
|      | SPIM_D2      | I/O  | MFP3  | SPIM data 2 pin for Quad Mode I/O.            |
|      | QSPI0_MISO1  | I/O  | MFP4  | Quad SPI0 MISO1 (Master In, Slave Out) pin.   |
|      | UART2_TXD    | O    | MFP8  | UART2 data transmitter output pin.            |
|      | I2C1_SCL     | I/O  | MFP9  | I <sup>2</sup> C1 clock pin.                  |
|      | CAN0_TXD     | O    | MFP10 | CAN0 bus transmitter output.                  |
|      | UART4_TXD    | O    | MFP11 | UART4 data transmitter output pin.            |
|      | EPWM1_CH0    | I/O  | MFP12 | EPWM1 channel 0 output/capture input.         |

|      | Pin Name         | Type | MFP   | Description                                            |
|------|------------------|------|-------|--------------------------------------------------------|
| PC.7 | UART4_RXD        | I    | MFP5  | UART4 data receiver input pin.                         |
|      | SC2_RST          | O    | MFP6  | Smart Card 2 reset pin.                                |
|      | UART0_nRTS       | O    | MFP7  | UART0 request to Send output pin.                      |
|      | I2C1_SMBSUS      | O    | MFP8  | I <sup>2</sup> C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|      | EPWM1_CH3        | I/O  | MFP11 | EPWM1 channel 3 output/capture input.                  |
|      | BPWM1_CH1        | I/O  | MFP12 | BPWM1 channel 1 output/capture input.                  |
|      | TM1              | I/O  | MFP14 | Timer1 event counter input/toggle output pin.          |
|      | INT2             | I    | MFP15 | External interrupt 2 input pin.                        |
|      | PC.7             | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_AD9          | I/O  | MFP2  | EBI address/data bus bit 9.                            |
| PC.8 | EMAC_RMII_RXD0   | I    | MFP3  | EMAC RMII Receive Data bus bit 0.                      |
|      | SPI1_MISO        | I/O  | MFP4  | SPI1 MISO (Master In, Slave Out) pin.                  |
|      | UART4_TXD        | O    | MFP5  | UART4 data transmitter output pin.                     |
|      | SC2_PWR          | O    | MFP6  | Smart Card 2 power pin.                                |
|      | UART0_nCTS       | I    | MFP7  | UART0 clear to Send input pin.                         |
|      | I2C1_SMBAL       | O    | MFP8  | I <sup>2</sup> C1 SMBus SMBALTER pin                   |
|      | EPWM1_CH2        | I/O  | MFP11 | EPWM1 channel 2 output/capture input.                  |
|      | BPWM1_CH0        | I/O  | MFP12 | BPWM1 channel 0 output/capture input.                  |
|      | TM0              | I/O  | MFP14 | Timer0 event counter input/toggle output pin.          |
|      | INT3             | I    | MFP15 | External interrupt 3 input pin.                        |
| PC.9 | PC.8             | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_ADR16        | O    | MFP2  | EBI address bus bit 16.                                |
|      | EMAC_RMII_REFCLK | I    | MFP3  | EMAC RMII reference clock input pin.                   |
|      | I2C0_SDA         | I/O  | MFP4  | I <sup>2</sup> C0 data input/output pin.               |
|      | UART4_nCTS       | I    | MFP5  | UART4 clear to Send input pin.                         |
|      | UART1_RXD        | I    | MFP8  | UART1 data receiver input pin.                         |
|      | EPWM1_CH1        | I/O  | MFP11 | EPWM1 channel 1 output/capture input.                  |
|      | BPWM1_CH4        | I/O  | MFP12 | BPWM1 channel 4 output/capture input.                  |

|       | Pin Name     | Type | MFP   | Description                                   |
|-------|--------------|------|-------|-----------------------------------------------|
| PC.10 | PC.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR6     | O    | MFP2  | EBI address bus bit 6.                        |
|       | SPI3_CLK     | I/O  | MFP6  | SPI3 serial clock pin.                        |
|       | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.            |
|       | CAN1_TXD     | O    | MFP9  | CAN1 bus transmitter output.                  |
|       | ECAP1_IC0    | I    | MFP11 | Enhanced capture unit 1 input 0 pin.          |
|       | EPWM1_CH2    | I/O  | MFP12 | EPWM1 channel 2 output/capture input.         |
| PC.11 | PC.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR5     | O    | MFP2  | EBI address bus bit 5.                        |
|       | UART0_RXD    | I    | MFP3  | UART0 data receiver input pin.                |
|       | I2C0_SDA     | I/O  | MFP4  | I <sup>2</sup> C0 data input/output pin.      |
|       | SPI3_MOSI    | I/O  | MFP6  | SPI3 MOSI (Master Out, Slave In) pin.         |
|       | ECAP1_IC1    | I    | MFP11 | Enhanced capture unit 1 input 1 pin.          |
|       | EPWM1_CH1    | I/O  | MFP12 | EPWM1 channel 1 output/capture input.         |
|       | ACMP1_O      | O    | MFP14 | Analog comparator 1 output pin.               |
| PC.12 | PC.12        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR4     | O    | MFP2  | EBI address bus bit 4.                        |
|       | UART0_TXD    | O    | MFP3  | UART0 data transmitter output pin.            |
|       | I2C0_SCL     | I/O  | MFP4  | I <sup>2</sup> C0 clock pin.                  |
|       | SPI3_MISO    | I/O  | MFP6  | SPI3 MISO (Master In, Slave Out) pin.         |
|       | SC0_nCD      | I    | MFP9  | Smart Card 0 card detect pin.                 |
|       | ECAP1_IC2    | I    | MFP11 | Enhanced capture unit 1 input 2 pin.          |
|       | EPWM1_CH0    | I/O  | MFP12 | EPWM1 channel 0 output/capture input.         |
|       | ACMP0_O      | O    | MFP14 | Analog comparator 0 output pin.               |
| PC.13 | PC.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR10    | O    | MFP2  | EBI address bus bit 10.                       |
|       | SC2_nCD      | I    | MFP3  | Smart Card 2 card detect pin.                 |
|       | SPI2_I2SMCLK | I/O  | MFP4  | SPI2 I <sup>2</sup> S master clock output pin |
|       | CAN1_TXD     | O    | MFP5  | CAN1 bus transmitter output.                  |
|       | USCI0_CTL0   | I/O  | MFP6  | USCI0 control 0 pin.                          |
|       | UART2_TXD    | O    | MFP7  | UART2 data transmitter output pin.            |
|       | BPWM0_CH4    | I/O  | MFP9  | BPWM0 channel 4 output/capture input.         |
|       | CLKO         | O    | MFP13 | Clock Out                                     |
|       | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.                 |

|       | Pin Name      | Type | MFP   | Description                                   |
|-------|---------------|------|-------|-----------------------------------------------|
| PC.14 | PC.14         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD11      | I/O  | MFP2  | EBI address/data bus bit 11.                  |
|       | SC1_nCD       | I    | MFP3  | Smart Card 1 card detect pin.                 |
|       | SPI0_I2SMCLK  | I/O  | MFP4  | SPI0 I <sup>2</sup> S master clock output pin |
|       | USCI0_CTL0    | I/O  | MFP5  | USCI0 control 0 pin.                          |
|       | QSPI0_CLK     | I/O  | MFP6  | Quad SPI0 serial clock pin.                   |
|       | EPWM0_SYNC_IN | I    | MFP11 | EPWM0 counter synchronous trigger input pin.  |
|       | TM1           | I/O  | MFP13 | Timer1 event counter input/toggle output pin. |
|       | USB_VBUS_ST   | I    | MFP14 | USB external VBUS regulator status pin.       |
|       | HSUSB_VBUS_ST | I    | MFP15 | HSUSB external VBUS regulator status pin.     |
| PD.0  | PD.0          | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD13      | I/O  | MFP2  | EBI address/data bus bit 13.                  |
|       | USCI0_CLK     | I/O  | MFP3  | USCI0 clock pin.                              |
|       | SPI0_MOSI     | I/O  | MFP4  | SPI0 MOSI (Master Out, Slave In) pin.         |
|       | UART3_RXD     | I    | MFP5  | UART3 data receiver input pin.                |
|       | I2C2_SDA      | I/O  | MFP6  | I <sup>2</sup> C2 data input/output pin.      |
|       | SC2_CLK       | O    | MFP7  | Smart Card 2 clock pin.                       |
|       | TM2           | I/O  | MFP14 | Timer2 event counter input/toggle output pin. |
| PD.1  | PD.1          | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD12      | I/O  | MFP2  | EBI address/data bus bit 12.                  |
|       | USCI0_DAT0    | I/O  | MFP3  | USCI0 data 0 pin.                             |
|       | SPI0_MISO     | I/O  | MFP4  | SPI0 MISO (Master In, Slave Out) pin.         |
|       | UART3_TXD     | O    | MFP5  | UART3 data transmitter output pin.            |
|       | I2C2_SCL      | I/O  | MFP6  | I <sup>2</sup> C2 clock pin.                  |
|       | SC2_DAT       | I/O  | MFP7  | Smart Card 2 data pin.                        |
| PD.2  | PD.2          | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD11      | I/O  | MFP2  | EBI address/data bus bit 11.                  |
|       | USCI0_DAT1    | I/O  | MFP3  | USCI0 data 1 pin.                             |
|       | SPI0_CLK      | I/O  | MFP4  | SPI0 serial clock pin.                        |
|       | UART3_nCTS    | I    | MFP5  | UART3 clear to Send input pin.                |
|       | SC2_RST       | O    | MFP7  | Smart Card 2 reset pin.                       |
|       | UART0_RXD     | I    | MFP9  | UART0 data receiver input pin.                |
| PD.3  | PD.3          | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD10      | I/O  | MFP2  | EBI address/data bus bit 10.                  |

|      | Pin Name    | Type | MFP   | Description                              |
|------|-------------|------|-------|------------------------------------------|
|      | USCI0_CTL1  | I/O  | MFP3  | USCI0 control 1 pin.                     |
|      | SPI0_SS     | I/O  | MFP4  | SPI0 slave select pin.                   |
|      | UART3_nRTS  | O    | MFP5  | UART3 request to Send output pin.        |
|      | USCI1_CTL0  | I/O  | MFP6  | USCI1 control 0 pin.                     |
|      | SC2_PWR     | O    | MFP7  | Smart Card 2 power pin.                  |
|      | SC1_nCD     | I    | MFP8  | Smart Card 1 card detect pin.            |
|      | UART0_TXD   | O    | MFP9  | UART0 data transmitter output pin.       |
| PD.4 | PD.4        | I/O  | MFP0  | General purpose digital I/O pin.         |
|      | USCI0_CTL0  | I/O  | MFP3  | USCI0 control 0 pin.                     |
|      | I2C1_SDA    | I/O  | MFP4  | I <sup>2</sup> C1 data input/output pin. |
|      | SPI1_SS     | I/O  | MFP5  | SPI1 slave select pin.                   |
|      | USCI1_CTL1  | I/O  | MFP6  | USCI1 control 1 pin.                     |
|      | SC1_CLK     | O    | MFP8  | Smart Card 1 clock pin.                  |
|      | USB_VBUS_ST | I    | MFP14 | USB external VBUS regulator status pin.  |
| PD.5 | PD.5        | I/O  | MFP0  | General purpose digital I/O pin.         |
|      | I2C1_SCL    | I/O  | MFP4  | I <sup>2</sup> C1 clock pin.             |
|      | SPI1_CLK    | I/O  | MFP5  | SPI1 serial clock pin.                   |
|      | USCI1_DAT0  | I/O  | MFP6  | USCI1 data 0 pin.                        |
|      | SC1_DAT     | I/O  | MFP8  | Smart Card 1 data pin.                   |
| PD.6 | PD.6        | I/O  | MFP0  | General purpose digital I/O pin.         |
|      | UART1_RXD   | I    | MFP3  | UART1 data receiver input pin.           |
|      | I2C0_SDA    | I/O  | MFP4  | I <sup>2</sup> C0 data input/output pin. |
|      | SPI1_MOSI   | I/O  | MFP5  | SPI1 MOSI (Master Out, Slave In) pin.    |
|      | USCI1_DAT1  | I/O  | MFP6  | USCI1 data 1 pin.                        |
|      | SC1_RST     | O    | MFP8  | Smart Card 1 reset pin.                  |
| PD.7 | PD.7        | I/O  | MFP0  | General purpose digital I/O pin.         |
|      | UART1_TXD   | O    | MFP3  | UART1 data transmitter output pin.       |
|      | I2C0_SCL    | I/O  | MFP4  | I <sup>2</sup> C0 clock pin.             |
|      | SPI1_MISO   | I/O  | MFP5  | SPI1 MISO (Master In, Slave Out) pin.    |
|      | USCI1_CLK   | I/O  | MFP6  | USCI1 clock pin.                         |
|      | SC1_PWR     | O    | MFP8  | Smart Card 1 power pin.                  |
| PD.8 | PD.8        | I/O  | MFP0  | General purpose digital I/O pin.         |
|      | EBI_AD6     | I/O  | MFP2  | EBI address/data bus bit 6.              |
|      | I2C2_SDA    | I/O  | MFP3  | I <sup>2</sup> C2 data input/output pin. |

|       | Pin Name     | Type | MFP   | Description                                   |
|-------|--------------|------|-------|-----------------------------------------------|
|       | UART2_nRTS   | O    | MFP4  | UART2 request to Send output pin.             |
| PD.9  | PD.9         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD7      | I/O  | MFP2  | EBI address/data bus bit 7.                   |
|       | I2C2_SCL     | I/O  | MFP3  | I <sup>2</sup> C clock pin.                   |
|       | UART2_nCTS   | I    | MFP4  | UART2 clear to Send input pin.                |
| PD.10 | PD.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | OPA2_P       | A    | MFP1  | Operational amplifier 2 positive input pin.   |
|       | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.                 |
|       | UART1_RXD    | I    | MFP3  | UART1 data receiver input pin.                |
|       | CAN0_RXD     | I    | MFP4  | CAN0 bus receiver input.                      |
|       | QEI0_B       | I    | MFP10 | Quadrature encoder 0 phase B input            |
|       | INT7         | I    | MFP15 | External interrupt 7 input pin.               |
| PD.11 | PD.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | OPA2_N       | A    | MFP1  | Operational amplifier 2 negative input pin.   |
|       | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.                 |
|       | UART1_TXD    | O    | MFP3  | UART1 data transmitter output pin.            |
|       | CAN0_TXD     | O    | MFP4  | CAN0 bus transmitter output.                  |
|       | QEI0_A       | I    | MFP10 | Quadrature encoder 0 phase A input            |
|       | INT6         | I    | MFP15 | External interrupt 6 input pin.               |
| PD.12 | PD.12        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | OPA2_O       | A    | MFP1  | Operational amplifier 2 output pin.           |
|       | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.                 |
|       | CAN1_RXD     | I    | MFP5  | CAN1 bus receiver input.                      |
|       | UART2_RXD    | I    | MFP7  | UART2 data receiver input pin.                |
|       | BPWM0_CH5    | I/O  | MFP9  | BPWM0 channel 5 output/capture input.         |
|       | QEI0_INDEX   | I    | MFP10 | Quadrature encoder 0 index input              |
|       | CLKO         | O    | MFP13 | Clock Out                                     |
|       | EADC0_ST     | I    | MFP14 | EADC0 external trigger input.                 |
|       | INT5         | I    | MFP15 | External interrupt 5 input pin.               |
| PD.13 | PD.13        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD10     | I/O  | MFP2  | EBI address/data bus bit 10.                  |
|       | SD0_nCD      | I    | MFP3  | SD/SDIO0 card detect input pin                |
|       | SPI0_I2SMCLK | I/O  | MFP4  | SPI0 I <sup>2</sup> S master clock output pin |
|       | SPI1_I2SMCLK | I/O  | MFP5  | SPI1 I <sup>2</sup> S master clock output pin |

|       | Pin Name     | Type | MFP   | Description                                   |
|-------|--------------|------|-------|-----------------------------------------------|
|       | SC2_nCD      | I    | MFP7  | Smart Card 2 card detect pin.                 |
| PD.14 | PD.14        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_nCS0     | O    | MFP2  | EBI chip select 0 output pin.                 |
|       | SPI3_I2SMCLK | I/O  | MFP3  | SPI3 I <sup>2</sup> S master clock output pin |
|       | SC1_nCD      | I    | MFP4  | Smart Card 1 card detect pin.                 |
|       | EPWM0_CH4    | I/O  | MFP11 | EPWM0 channel 4 output/capture input.         |
| PE.0  | PE.0         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD11     | I/O  | MFP2  | EBI address/data bus bit 11.                  |
|       | QSPI0_MOSI0  | I/O  | MFP3  | Quad SPI0 MOSI0 (Master Out, Slave In) pin.   |
|       | SC2_CLK      | O    | MFP4  | Smart Card 2 clock pin.                       |
|       | I2S0_MCLK    | O    | MFP5  | I <sup>2</sup> S0 master clock output pin.    |
|       | SPI1_MOSI    | I/O  | MFP6  | SPI1 MOSI (Master Out, Slave In) pin.         |
|       | UART3_RXD    | I    | MFP7  | UART3 data receiver input pin.                |
|       | I2C1_SDA     | I/O  | MFP8  | I <sup>2</sup> C1 data input/output pin.      |
|       | UART4_nRTS   | O    | MFP9  | UART4 request to Send output pin.             |
| PE.1  | PE.1         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_AD10     | I/O  | MFP2  | EBI address/data bus bit 10.                  |
|       | QSPI0_MISO0  | I/O  | MFP3  | Quad SPI0 MISO0 (Master In, Slave Out) pin.   |
|       | SC2_DAT      | I/O  | MFP4  | Smart Card 2 data pin.                        |
|       | I2S0_BCLK    | O    | MFP5  | I <sup>2</sup> S0 bit clock output pin.       |
|       | SPI1_MISO    | I/O  | MFP6  | SPI1 MISO (Master In, Slave Out) pin.         |
|       | UART3_TXD    | O    | MFP7  | UART3 data transmitter output pin.            |
|       | I2C1_SCL     | I/O  | MFP8  | I <sup>2</sup> C1 clock pin.                  |
|       | UART4_nCTS   | I    | MFP9  | UART4 clear to Send input pin.                |
| PE.2  | PE.2         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ALE      | O    | MFP2  | EBI address latch enable output pin.          |
|       | SD0_DAT0     | I/O  | MFP3  | SD/SDIO0 data line bit 0.                     |
|       | SPIM_MOSI    | I/O  | MFP4  | SPIM MOSI (Master Out, Slave In) pin.         |
|       | SPI3_MOSI    | I/O  | MFP5  | SPI3 MOSI (Master Out, Slave In) pin.         |
|       | SC0_CLK      | O    | MFP6  | Smart Card 0 clock pin.                       |
|       | USCI0_CLK    | I/O  | MFP7  | USCI0 clock pin.                              |
|       | QEIO_B       | I    | MFP11 | Quadrature encoder 0 phase B input            |
|       | EPWM0_CH5    | I/O  | MFP12 | EPWM0 channel 5 output/capture input.         |
|       | BPWM0_CH0    | I/O  | MFP13 | BPWM0 channel 0 output/capture input.         |

|      | Pin Name     | Type | MFP   | Description                                   |
|------|--------------|------|-------|-----------------------------------------------|
| PE.3 | PE.3         | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EBI_MCLK     | O    | MFP2  | EBI external clock output pin.                |
|      | SD0_DAT1     | I/O  | MFP3  | SD/SDIO0 data line bit 1.                     |
|      | SPIIM_MISO   | I/O  | MFP4  | SPIIM MISO (Master In, Slave Out) pin.        |
|      | SPI3_MISO    | I/O  | MFP5  | SPI3 MISO (Master In, Slave Out) pin.         |
|      | SC0_DAT      | I/O  | MFP6  | Smart Card 0 data pin.                        |
|      | USCI0_DAT0   | I/O  | MFP7  | USCI0 data 0 pin.                             |
|      | QEIO_A       | I    | MFP11 | Quadrature encoder 0 phase A input            |
|      | EPWM0_CH4    | I/O  | MFP12 | EPWM0 channel 4 output/capture input.         |
|      | BPWM0_CH1    | I/O  | MFP13 | BPWM0 channel 1 output/capture input.         |
| PE.4 | PE.4         | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EBI_nWR      | O    | MFP2  | EBI write enable output pin.                  |
|      | SD0_DAT2     | I/O  | MFP3  | SD/SDIO0 data line bit 2.                     |
|      | SPIIM_CLK    | I/O  | MFP4  | SPIIM serial clock pin.                       |
|      | SPI3_CLK     | I/O  | MFP5  | SPI3 serial clock pin.                        |
|      | SC0_RST      | O    | MFP6  | Smart Card 0 reset pin.                       |
|      | USCI0_DAT1   | I/O  | MFP7  | USCI0 data 1 pin.                             |
|      | QEIO_INDEX   | I    | MFP11 | Quadrature encoder 0 index input              |
|      | EPWM0_CH3    | I/O  | MFP12 | EPWM0 channel 3 output/capture input.         |
|      | BPWM0_CH2    | I/O  | MFP13 | BPWM0 channel 2 output/capture input.         |
| PE.5 | PE.5         | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | EBI_nRD      | O    | MFP2  | EBI read enable output pin.                   |
|      | SD0_DAT3     | I/O  | MFP3  | SD/SDIO0 data line bit 3.                     |
|      | SPIIM_SS     | I/O  | MFP4  | SPIIM slave select pin.                       |
|      | SPI3_SS      | I/O  | MFP5  | SPI3 slave select pin.                        |
|      | SC0_PWR      | O    | MFP6  | Smart Card 0 power pin.                       |
|      | USCI0_CTL1   | I/O  | MFP7  | USCI0 control 1 pin.                          |
|      | QEII_B       | I    | MFP11 | Quadrature encoder 1 phase B input            |
|      | EPWM0_CH2    | I/O  | MFP12 | EPWM0 channel 2 output/capture input.         |
|      | BPWM0_CH3    | I/O  | MFP13 | BPWM0 channel 3 output/capture input.         |
| PE.6 | PE.6         | I/O  | MFP0  | General purpose digital I/O pin.              |
|      | SD0_CLK      | O    | MFP3  | SD/SDIO0 clock output pin                     |
|      | SPIIM_D3     | I/O  | MFP4  | SPIIM data 3 pin for Quad Mode I/O.           |
|      | SPI3_I2SMCLK | I/O  | MFP5  | SPI3 I <sup>2</sup> S master clock output pin |

|       | Pin Name       | Type | MFP   | Description                                |
|-------|----------------|------|-------|--------------------------------------------|
| PE.7  | SC0_nCD        | I    | MFP6  | Smart Card 0 card detect pin.              |
|       | USCI0_CTL0     | I/O  | MFP7  | USCI0 control 0 pin.                       |
|       | UART5_RXD      | I    | MFP8  | UART5 data receiver input pin.             |
|       | CAN1_RXD       | I    | MFP9  | CAN1 bus receiver input.                   |
|       | QEI1_A         | I    | MFP11 | Quadrature encoder 1 phase A input         |
|       | EPWM0_CH1      | I/O  | MFP12 | EPWM0 channel 1 output/capture input.      |
|       | BPWM0_CH4      | I/O  | MFP13 | BPWM0 channel 4 output/capture input.      |
|       | PE.7           | I/O  | MFP0  | General purpose digital I/O pin.           |
| PE.8  | SD0_CMD        | I/O  | MFP3  | SD/SDIO0 command/response pin              |
|       | SPI_M2         | I/O  | MFP4  | SPI_M data 2 pin for Quad Mode I/O.        |
|       | UART5_TXD      | O    | MFP8  | UART5 data transmitter output pin.         |
|       | CAN1_TXD       | O    | MFP9  | CAN1 bus transmitter output.               |
|       | QEI1_INDEX     | I    | MFP11 | Quadrature encoder 1 index input           |
|       | EPWM0_CH0      | I/O  | MFP12 | EPWM0 channel 0 output/capture input.      |
|       | BPWM0_CH5      | I/O  | MFP13 | BPWM0 channel 5 output/capture input.      |
|       | PE.8           | I/O  | MFP0  | General purpose digital I/O pin.           |
|       | EBI_ADR10      | O    | MFP2  | EBI address bus bit 10.                    |
|       | EMAC_RMII_MDC  | O    | MFP3  | EMAC RMII PHY Management Clock output pin. |
|       | I2S0_BCLK      | O    | MFP4  | I <sup>2</sup> S0 bit clock output pin.    |
| PE.9  | SPI2_CLK       | I/O  | MFP5  | SPI2 serial clock pin.                     |
|       | USCI1_CTL1     | I/O  | MFP6  | USCI1 control 1 pin.                       |
|       | UART2_TXD      | O    | MFP7  | UART2 data transmitter output pin.         |
|       | EPWM0_CH0      | I/O  | MFP10 | EPWM0 channel 0 output/capture input.      |
|       | EPWM0_BRAKE0   | I    | MFP11 | EPWM0 Brake 0 input pin.                   |
|       | ECAP0_IC0      | I    | MFP12 | Enhanced capture unit 0 input 0 pin.       |
|       | TRACE_CLK      | O    | MFP14 | ETM Trace Clock output pin                 |
|       | PE.9           | I/O  | MFP0  | General purpose digital I/O pin.           |
|       | EBI_ADR11      | O    | MFP2  | EBI address bus bit 11.                    |
|       | EMAC_RMII_MDIO | I/O  | MFP3  | EMAC RMII PHY Management Data pin.         |
| PE.10 | I2S0_MCLK      | O    | MFP4  | I <sup>2</sup> S0 master clock output pin. |
|       | SPI2_MISO      | I/O  | MFP5  | SPI2 MISO (Master In, Slave Out) pin.      |
|       | USCI1_CTL0     | I/O  | MFP6  | USCI1 control 0 pin.                       |
|       | UART2_RXD      | I    | MFP7  | UART2 data receiver input pin.             |
|       | EPWM0_CH1      | I/O  | MFP10 | EPWM0 channel 1 output/capture input.      |

|       | Pin Name       | Type | MFP   | Description                                            |
|-------|----------------|------|-------|--------------------------------------------------------|
|       | EPWM0_BRAKE1   | I    | MFP11 | EPWM0 Brake 1 input pin.                               |
|       | ECAP0_IC1      | I    | MFP12 | Enhanced capture unit 0 input 1 pin.                   |
|       | TRACE_DATA0    | O    | MFP14 | ETM Trace Data 0 output pin                            |
| PE.10 | PE.10          | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_ADR12      | O    | MFP2  | EBI address bus bit 12.                                |
|       | EMAC_RMII_TXD0 | O    | MFP3  | EMAC RMII Transmit Data bus bit 0.                     |
|       | I2S0_DI        | I    | MFP4  | I <sup>2</sup> S0 data input pin.                      |
|       | SPI2_MOSI      | I/O  | MFP5  | SPI2 MOSI (Master Out, Slave In) pin.                  |
|       | USCI1_DAT0     | I/O  | MFP6  | USCI1 data 0 pin.                                      |
|       | UART3_TXD      | O    | MFP7  | UART3 data transmitter output pin.                     |
|       | EPWM0_CH2      | I/O  | MFP10 | EPWM0 channel 2 output/capture input.                  |
|       | EPWM1_BRAKE0   | I    | MFP11 | EPWM1 Brake 0 input pin.                               |
|       | ECAP0_IC2      | I    | MFP12 | Enhanced capture unit 0 input 2 pin.                   |
| PE.11 | TRACE_DATA1    | O    | MFP14 | ETM Trace Data 1 output pin                            |
|       | PE.11          | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_ADR13      | O    | MFP2  | EBI address bus bit 13.                                |
|       | EMAC_RMII_TXD1 | O    | MFP3  | EMAC RMII Transmit Data bus bit 1.                     |
|       | I2S0_DO        | O    | MFP4  | I <sup>2</sup> S0 data output pin.                     |
|       | SPI2_SS        | I/O  | MFP5  | SPI2 slave select pin.                                 |
|       | USCI1_DAT1     | I/O  | MFP6  | USCI1 data 1 pin.                                      |
|       | UART3_RXD      | I    | MFP7  | UART3 data receiver input pin.                         |
|       | UART1_nCTS     | I    | MFP8  | UART1 clear to Send input pin.                         |
|       | EPWM0_CH3      | I/O  | MFP10 | EPWM0 channel 3 output/capture input.                  |
| PE.12 | EPWM1_BRAKE1   | I    | MFP11 | EPWM1 Brake 1 input pin.                               |
|       | ECAP1_IC2      | I    | MFP13 | Enhanced capture unit 1 input 2 pin.                   |
|       | TRACE_DATA2    | O    | MFP14 | ETM Trace Data 2 output pin                            |
|       | PE.12          | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_ADR14      | O    | MFP2  | EBI address bus bit 14.                                |
|       | EMAC_RMII_TXEN | O    | MFP3  | EMAC RMII Transmit Enable output pin.                  |
|       | I2S0_LRCK      | O    | MFP4  | I <sup>2</sup> S0 left right channel clock output pin. |
|       | SPI2_I2SMCLK   | I/O  | MFP5  | SPI2 I <sup>2</sup> S master clock output pin          |

|       | Pin Name    | Type | MFP   | Description                              |
|-------|-------------|------|-------|------------------------------------------|
|       | ECAP1_IC1   | I    | MFP13 | Enhanced capture unit 1 input 1 pin.     |
|       | TRACE_DATA3 | O    | MFP14 | ETM Trace Data 3 output pin              |
| PE.13 | PE.13       | I/O  | MFP0  | General purpose digital I/O pin.         |
|       | EBI_ADR15   | O    | MFP2  | EBI address bus bit 15.                  |
|       | EMAC_PPS    | O    | MFP3  | EMAC Pulse Per Second output pin.        |
|       | I2C0_SCL    | I/O  | MFP4  | I <sup>2</sup> C0 clock pin.             |
|       | UART4_nRTS  | O    | MFP5  | UART4 request to Send output pin.        |
|       | UART1_TXD   | O    | MFP8  | UART1 data transmitter output pin.       |
|       | EPWM0_CH5   | I/O  | MFP10 | EPWM0 channel 5 output/capture input.    |
|       | EPWM1_CH0   | I/O  | MFP11 | EPWM1 channel 0 output/capture input.    |
|       | BPWM1_CH5   | I/O  | MFP12 | BPWM1 channel 5 output/capture input.    |
|       | ECAP1_IC0   | I    | MFP13 | Enhanced capture unit 1 input 0 pin.     |
| PE.14 | PE.14       | I/O  | MFP0  | General purpose digital I/O pin.         |
|       | EBI_AD8     | I/O  | MFP2  | EBI address/data bus bit 8.              |
|       | UART2_TXD   | O    | MFP3  | UART2 data transmitter output pin.       |
|       | CAN0_TXD    | O    | MFP4  | CAN0 bus transmitter output.             |
|       | SD1_nCD     | I    | MFP5  | SD/SDIO1 card detect input pin           |
| PE.15 | PE.15       | I/O  | MFP0  | General purpose digital I/O pin.         |
|       | EBI_AD9     | I/O  | MFP2  | EBI address/data bus bit 9.              |
|       | UART2_RXD   | I    | MFP3  | UART2 data receiver input pin.           |
|       | CAN0_RXD    | I    | MFP4  | CAN0 bus receiver input.                 |
| PF.0  | PF.0        | I/O  | MFP0  | General purpose digital I/O pin.         |
|       | UART1_TXD   | O    | MFP2  | UART1 data transmitter output pin.       |
|       | I2C1_SCL    | I/O  | MFP3  | I <sup>2</sup> C1 clock pin.             |
|       | BPWM1_CH0   | I/O  | MFP12 | BPWM1 channel 0 output/capture input.    |
|       | ICE_DAT     | O    | MFP14 | Serial wired debugger data pin.          |
| PF.1  | PF.1        | I/O  | MFP0  | General purpose digital I/O pin.         |
|       | UART1_RXD   | I    | MFP2  | UART1 data receiver input pin.           |
|       | I2C1_SDA    | I/O  | MFP3  | I <sup>2</sup> C1 data input/output pin. |
|       | BPWM1_CH1   | I/O  | MFP12 | BPWM1 channel 1 output/capture input.    |
|       | ICE_CLK     | I    | MFP14 | Serial wired debugger clock pin.         |
| PF.2  | PF.2        | I/O  | MFP0  | General purpose digital I/O pin.         |
|       | EBI_nCS1    | O    | MFP2  | EBI chip select 1 output pin.            |
|       | UART0_RXD   | I    | MFP3  | UART0 data receiver input pin.           |

|      | Pin Name       | Type | MFP   | Description                                            |
|------|----------------|------|-------|--------------------------------------------------------|
| PF.3 | I2C0_SDA       | I/O  | MFP4  | I <sup>2</sup> C0 data input/output pin.               |
|      | QSPI0_CLK      | I/O  | MFP5  | Quad SPI0 serial clock pin.                            |
|      | XT1_OUT        | O    | MFP10 | External 4~24 MHz (high speed) crystal output pin.     |
|      | BPWM1_CH1      | I/O  | MFP11 | BPWM1 channel 1 output/capture input.                  |
| PF.4 | PF.3           | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_nCS0       | O    | MFP2  | EBI chip select 0 output pin.                          |
|      | UART0_TXD      | O    | MFP3  | UART0 data transmitter output pin.                     |
|      | I2C0_SCL       | I/O  | MFP4  | I <sup>2</sup> C0 clock pin.                           |
|      | XT1_IN         | I    | MFP10 | External 4~24 MHz (high speed) crystal input pin.      |
|      | BPWM1_CH0      | I/O  | MFP11 | BPWM1 channel 0 output/capture input.                  |
| PF.5 | PF.4           | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | UART2_TXD      | O    | MFP2  | UART2 data transmitter output pin.                     |
|      | UART2_nRTS     | O    | MFP4  | UART2 request to Send output pin.                      |
|      | BPWM0_CH5      | I/O  | MFP8  | BPWM0 channel 5 output/capture input.                  |
|      | X32_OUT        | O    | MFP10 | External 32.768 kHz crystal output pin.                |
|      | PF.5           | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | UART2_RXD      | I    | MFP2  | UART2 data receiver input pin.                         |
| PF.6 | UART2_nCTS     | I    | MFP4  | UART2 clear to Send input pin.                         |
|      | BPWM0_CH4      | I/O  | MFP8  | BPWM0 channel 4 output/capture input.                  |
|      | EPWM0_SYNC_OUT | O    | MFP9  | EPWM0 counter synchronous trigger output pin.          |
|      | X32_IN         | I    | MFP10 | External 32.768 kHz crystal input pin.                 |
|      | EADC0_ST       | I    | MFP11 | EADC0 external trigger input.                          |
|      | PF.6           | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_ADR19      | O    | MFP2  | EBI address bus bit 19.                                |
|      | SC0_CLK        | O    | MFP3  | Smart Card 0 clock pin.                                |
| PF.7 | I2S0_LRCK      | O    | MFP4  | I <sup>2</sup> S0 left right channel clock output pin. |
|      | SPI0_MOSI      | I/O  | MFP5  | SPI0 MOSI (Master Out, Slave In) pin.                  |
|      | UART4_RXD      | I    | MFP6  | UART4 data receiver input pin.                         |
|      | EBI_nCS0       | O    | MFP7  | EBI chip select 0 output pin.                          |
|      | TAMPER0        | I/O  | MFP10 | TAMPER detector loop pin 0.                            |
|      | PF.7           | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_ADR18      | O    | MFP2  | EBI address bus bit 18.                                |
| PF.7 | SC0_DAT        | I/O  | MFP3  | Smart Card 0 data pin.                                 |
|      | I2S0_DO        | O    | MFP4  | I <sup>2</sup> S0 data output pin.                     |

|       | Pin Name     | Type | MFP   | Description                                   |
|-------|--------------|------|-------|-----------------------------------------------|
|       | SPI0_MISO    | I/O  | MFP5  | SPI0 MISO (Master In, Slave Out) pin.         |
|       | UART4_TXD    | O    | MFP6  | UART4 data transmitter output pin.            |
|       | TAMPER1      | I/O  | MFP10 | TAMPER detector loop pin 1.                   |
| PF.8  | PF.8         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR17    | O    | MFP2  | EBI address bus bit 17.                       |
|       | SC0_RST      | O    | MFP3  | Smart Card 0 reset pin.                       |
|       | I2S0_DI      | I    | MFP4  | I <sup>2</sup> S0 data input pin.             |
|       | SPI0_CLK     | I/O  | MFP5  | SPI0 serial clock pin.                        |
|       | TAMPER2      | I/O  | MFP10 | TAMPER detector loop pin 2.                   |
| PF.9  | PF.9         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR16    | O    | MFP2  | EBI address bus bit 16.                       |
|       | SC0_PWR      | O    | MFP3  | Smart Card 0 power pin.                       |
|       | I2S0_MCLK    | O    | MFP4  | I <sup>2</sup> S0 master clock output pin.    |
|       | SPI0_SS      | I/O  | MFP5  | SPI0 slave select pin.                        |
|       | TAMPER3      | I/O  | MFP10 | TAMPER detector loop pin 3.                   |
| PF.10 | PF.10        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR15    | O    | MFP2  | EBI address bus bit 15.                       |
|       | SC0_nCD      | I    | MFP3  | Smart Card 0 card detect pin.                 |
|       | I2S0_BCLK    | O    | MFP4  | I <sup>2</sup> S0 bit clock output pin.       |
|       | SPI0_I2SMCLK | I/O  | MFP5  | SPI0 I <sup>2</sup> S master clock output pin |
|       | TAMPER4      | I/O  | MFP10 | TAMPER detector loop pin 4.                   |
| PF.11 | PF.11        | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR14    | O    | MFP2  | EBI address bus bit 14.                       |
|       | SPI2_MOSI    | I/O  | MFP3  | SPI2 MOSI (Master Out, Slave In) pin.         |
|       | TAMPER5      | I/O  | MFP10 | TAMPER detector loop pin 5.                   |
|       | TM3          | I/O  | MFP13 | Timer3 event counter input/toggle output pin. |
| PG.0  | PG.0         | I/O  | MFP0  | General purpose digital I/O pin.              |
|       | EBI_ADR8     | O    | MFP2  | EBI address bus bit 8.                        |
|       | I2C0_SCL     | I/O  | MFP4  | I <sup>2</sup> C0 clock pin.                  |
|       | I2C1_SMBAL   | O    | MFP5  | I <sup>2</sup> C1 SMBus SMBALTER pin          |
|       | UART2_RXD    | I    | MFP6  | UART2 data receiver input pin.                |
|       | CAN1_TXD     | O    | MFP7  | CAN1 bus transmitter output.                  |
|       | UART1_TXD    | O    | MFP8  | UART1 data transmitter output pin.            |
| PG.1  | PG.1         | I/O  | MFP0  | General purpose digital I/O pin.              |

|      | Pin Name     | Type | MFP   | Description                                            |
|------|--------------|------|-------|--------------------------------------------------------|
| PG.2 | EBI_ADR9     | O    | MFP2  | EBI address bus bit 9.                                 |
|      | SPI2_I2SMCLK | I/O  | MFP3  | SPI2 I <sup>2</sup> S master clock output pin          |
|      | I2C0_SDA     | I/O  | MFP4  | I <sup>2</sup> C0 data input/output pin.               |
|      | I2C1_SMBSUS  | O    | MFP5  | I <sup>2</sup> C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|      | UART2_TXD    | O    | MFP6  | UART2 data transmitter output pin.                     |
|      | CAN1_RXD     | I    | MFP7  | CAN1 bus receiver input.                               |
|      | UART1_RXD    | I    | MFP8  | UART1 data receiver input pin.                         |
| PG.3 | PG.2         | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_ADR11    | O    | MFP2  | EBI address bus bit 11.                                |
|      | SPI2_SS      | I/O  | MFP3  | SPI2 slave select pin.                                 |
|      | I2C0_SMBAL   | O    | MFP4  | I <sup>2</sup> C0 SMBus SMBALTER pin                   |
|      | I2C1_SCL     | I/O  | MFP5  | I <sup>2</sup> C1 clock pin.                           |
|      | TM0          | I/O  | MFP13 | Timer0 event counter input/toggle output pin.          |
| PG.4 | PG.3         | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_ADR12    | O    | MFP2  | EBI address bus bit 12.                                |
|      | SPI2_CLK     | I/O  | MFP3  | SPI2 serial clock pin.                                 |
|      | I2C0_SMBSUS  | O    | MFP4  | I <sup>2</sup> C0 SMBus SMBSUS pin (PMBus CONTROL pin) |
|      | I2C1_SDA     | I/O  | MFP5  | I <sup>2</sup> C1 data input/output pin.               |
|      | TM1          | I/O  | MFP13 | Timer1 event counter input/toggle output pin.          |
| PG.5 | PG.4         | I/O  | MFP0  | General purpose digital I/O pin.                       |
|      | EBI_ADR13    | O    | MFP2  | EBI address bus bit 13.                                |
|      | SPI2_MISO    | I/O  | MFP3  | SPI2 MISO (Master In, Slave Out) pin.                  |
|      | TM2          | I/O  | MFP13 | Timer2 event counter input/toggle output pin.          |
|      | PG.5         | I/O  | MFP0  | General purpose digital I/O pin.                       |
| PG.6 | EBI_nCS1     | O    | MFP2  | EBI chip select 1 output pin.                          |
|      | SPI3_SS      | I/O  | MFP3  | SPI3 slave select pin.                                 |
|      | SC1_PWR      | O    | MFP4  | Smart Card 1 power pin.                                |
|      | EPWM0_CH3    | I/O  | MFP11 | EPWM0 channel 3 output/capture input.                  |
|      | PG.6         | I/O  | MFP0  | General purpose digital I/O pin.                       |
| PG.7 | EBI_nCS2     | O    | MFP2  | EBI chip select 2 output pin.                          |
|      | SPI3_CLK     | I/O  | MFP3  | SPI3 serial clock pin.                                 |
|      | SC1_RST      | O    | MFP4  | Smart Card 1 reset pin.                                |
|      | EPWM0_CH2    | I/O  | MFP11 | EPWM0 channel 2 output/capture input.                  |
|      | PG.7         | I/O  | MFP0  | General purpose digital I/O pin.                       |

|       | Pin Name  | Type | MFP   | Description                           |
|-------|-----------|------|-------|---------------------------------------|
| PG.8  | EBI_nWRL  | O    | MFP2  | EBI low byte write enable output pin. |
|       | SPI3_MISO | I/O  | MFP3  | SPI3 MISO (Master In, Slave Out) pin. |
|       | SC1_DAT   | I/O  | MFP4  | Smart Card 1 data pin.                |
|       | EPWM0_CH1 | I/O  | MFP11 | EPWM0 channel 1 output/capture input. |
| PG.9  | PG.8      | I/O  | MFP0  | General purpose digital I/O pin.      |
|       | EBI_nWRH  | O    | MFP2  | EBI high byte write enable output pin |
|       | SPI3_MOSI | I/O  | MFP3  | SPI3 MOSI (Master Out, Slave In) pin. |
|       | SC1_CLK   | O    | MFP4  | Smart Card 1 clock pin.               |
|       | EPWM0_CH0 | I/O  | MFP11 | EPWM0 channel 0 output/capture input. |
| PG.10 | PG.9      | I/O  | MFP0  | General purpose digital I/O pin.      |
|       | EBI_AD0   | I/O  | MFP2  | EBI address/data bus bit 0.           |
|       | SD1_DAT3  | I/O  | MFP3  | SD/SDIO1 data line bit 3.             |
|       | SPIM_D2   | I/O  | MFP4  | SPIM data 2 pin for Quad Mode I/O.    |
|       | BPWM0_CH5 | I/O  | MFP12 | BPWM0 channel 5 output/capture input. |
| PG.11 | PG.10     | I/O  | MFP0  | General purpose digital I/O pin.      |
|       | EBI_AD1   | I/O  | MFP2  | EBI address/data bus bit 1.           |
|       | SD1_DAT2  | I/O  | MFP3  | SD/SDIO1 data line bit 2.             |
|       | SPIM_D3   | I/O  | MFP4  | SPIM data 3 pin for Quad Mode I/O.    |
|       | BPWM0_CH4 | I/O  | MFP12 | BPWM0 channel 4 output/capture input. |
| PG.12 | PG.11     | I/O  | MFP0  | General purpose digital I/O pin.      |
|       | EBI_AD2   | I/O  | MFP2  | EBI address/data bus bit 2.           |
|       | SD1_DAT1  | I/O  | MFP3  | SD/SDIO1 data line bit 1.             |
|       | SPIM_SS   | I/O  | MFP4  | SPIM slave select pin.                |
|       | BPWM0_CH3 | I/O  | MFP12 | BPWM0 channel 3 output/capture input. |
| PG.13 | PG.12     | I/O  | MFP0  | General purpose digital I/O pin.      |
|       | EBI_AD3   | I/O  | MFP2  | EBI address/data bus bit 3.           |
|       | SD1_DAT0  | I/O  | MFP3  | SD/SDIO1 data line bit 0.             |
|       | SPIM_CLK  | I/O  | MFP4  | SPIM serial clock pin.                |
|       | BPWM0_CH2 | I/O  | MFP12 | BPWM0 channel 2 output/capture input. |
|       | PG.13     | I/O  | MFP0  | General purpose digital I/O pin.      |
|       | EBI_AD4   | I/O  | MFP2  | EBI address/data bus bit 4.           |
|       | SD1_CMD   | I/O  | MFP3  | SD/SDIO1 command/response pin         |
|       | SPIM_MISO | I/O  | MFP4  | SPIM MISO (Master In, Slave Out) pin. |
|       | BPWM0_CH1 | I/O  | MFP12 | BPWM0 channel 1 output/capture input. |

|       | Pin Name     | Type | MFP   | Description                                      |
|-------|--------------|------|-------|--------------------------------------------------|
| PG.14 | PG.14        | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | EBI_AD5      | I/O  | MFP2  | EBI address/data bus bit 5.                      |
|       | SD1_CLK      | O    | MFP3  | SD/SDIO1 clock output pin                        |
|       | SPI1_MOSI    | I/O  | MFP4  | SPI1 MOSI (Master Out, Slave In) pin.            |
|       | BPWM0_CH0    | I/O  | MFP12 | BPWM0 channel 0 output/capture input.            |
| PG.15 | PG.15        | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | SD1_nCD      | I    | MFP3  | SD/SDIO1 card detect input pin                   |
|       | CLKO         | O    | MFP14 | Clock Out                                        |
|       | EADC0_ST     | I    | MFP15 | EADC0 external trigger input.                    |
| PH.0  | PH.0         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | EBI_ADR7     | O    | MFP2  | EBI address bus bit 7.                           |
|       | UART5_TXD    | O    | MFP4  | UART5 data transmitter output pin.               |
|       | TM0_EXT      | I/O  | MFP13 | Timer0 external capture input/toggle output pin. |
| PH.1  | PH.1         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | EBI_ADR6     | O    | MFP2  | EBI address bus bit 6.                           |
|       | UART5_RXD    | I    | MFP4  | UART5 data receiver input pin.                   |
|       | TM1_EXT      | I/O  | MFP13 | Timer1 external capture input/toggle output pin. |
| PH.2  | PH.2         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | EBI_ADR5     | O    | MFP2  | EBI address bus bit 5.                           |
|       | UART5_nRTS   | O    | MFP4  | UART5 request to Send output pin.                |
|       | UART4_TXD    | O    | MFP5  | UART4 data transmitter output pin.               |
|       | I2C0_SCL     | I/O  | MFP6  | I <sup>2</sup> C0 clock pin.                     |
|       | TM2_EXT      | I/O  | MFP13 | Timer2 external capture input/toggle output pin. |
| PH.3  | PH.3         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | EBI_ADR4     | O    | MFP2  | EBI address bus bit 4.                           |
|       | SPI1_I2SMCLK | I/O  | MFP3  | SPI1 I <sup>2</sup> S master clock output pin    |
|       | UART5_nCTS   | I    | MFP4  | UART5 clear to Send input pin.                   |
|       | UART4_RXD    | I    | MFP5  | UART4 data receiver input pin.                   |
|       | I2C0_SDA     | I/O  | MFP6  | I <sup>2</sup> C0 data input/output pin.         |
|       | TM3_EXT      | I/O  | MFP13 | Timer3 external capture input/toggle output pin. |
| PH.4  | PH.4         | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | EBI_ADR3     | O    | MFP2  | EBI address bus bit 3.                           |
|       | SPI1_MISO    | I/O  | MFP3  | SPI1 MISO (Master In, Slave Out) pin.            |
| PH.5  | PH.5         | I/O  | MFP0  | General purpose digital I/O pin.                 |

|       | Pin Name     | Type | MFP   | Description                                            |
|-------|--------------|------|-------|--------------------------------------------------------|
|       | EBI_ADR2     | O    | MFP2  | EBI address bus bit 2.                                 |
|       | SPI1_MOSI    | I/O  | MFP3  | SPI1 MOSI (Master Out, Slave In) pin.                  |
| PH.6  | PH.6         | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_ADR1     | O    | MFP2  | EBI address bus bit 1.                                 |
|       | SPI1_CLK     | I/O  | MFP3  | SPI1 serial clock pin.                                 |
| PH.7  | PH.7         | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_ADR0     | O    | MFP2  | EBI address bus bit 0.                                 |
|       | SPI1_SS      | I/O  | MFP3  | SPI1 slave select pin.                                 |
| PH.8  | PH.8         | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_AD12     | I/O  | MFP2  | EBI address/data bus bit 12.                           |
|       | QSPI0_CLK    | I/O  | MFP3  | Quad SPI0 serial clock pin.                            |
|       | SC2_PWR      | O    | MFP4  | Smart Card 2 power pin.                                |
|       | I2S0_DI      | I    | MFP5  | I <sup>2</sup> S0 data input pin.                      |
|       | SPI1_CLK     | I/O  | MFP6  | SPI1 serial clock pin.                                 |
|       | UART3_nRTS   | O    | MFP7  | UART3 request to Send output pin.                      |
|       | I2C1_SMBAL   | O    | MFP8  | I <sup>2</sup> C1 SMBus SMBALTER pin                   |
|       | I2C2_SCL     | I/O  | MFP9  | I <sup>2</sup> C2 clock pin.                           |
|       | UART1_TXD    | O    | MFP10 | UART1 data transmitter output pin.                     |
| PH.9  | PH.9         | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_AD13     | I/O  | MFP2  | EBI address/data bus bit 13.                           |
|       | QSPI0_SS     | I/O  | MFP3  | Quad SPI0 slave select pin.                            |
|       | SC2_RST      | O    | MFP4  | Smart Card 2 reset pin.                                |
|       | I2S0_DO      | O    | MFP5  | I <sup>2</sup> S0 data output pin.                     |
|       | SPI1_SS      | I/O  | MFP6  | SPI1 slave select pin.                                 |
|       | UART3_nCTS   | I    | MFP7  | UART3 clear to Send input pin.                         |
|       | I2C1_SMBSUS  | O    | MFP8  | I <sup>2</sup> C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
|       | I2C2_SDA     | I/O  | MFP9  | I <sup>2</sup> C2 data input/output pin.               |
|       | UART1_RXD    | I    | MFP10 | UART1 data receiver input pin.                         |
| PH.10 | PH.10        | I/O  | MFP0  | General purpose digital I/O pin.                       |
|       | EBI_AD14     | I/O  | MFP2  | EBI address/data bus bit 14.                           |
|       | QSPI0_MISO1  | I/O  | MFP3  | Quad SPI0 MISO1 (Master In, Slave Out) pin.            |
|       | SC2_nCD      | I    | MFP4  | Smart Card 2 card detect pin.                          |
|       | I2S0_LRCK    | O    | MFP5  | I <sup>2</sup> S0 left right channel clock output pin. |
|       | SPI1_I2SMCLK | I/O  | MFP6  | SPI1 I <sup>2</sup> S master clock output pin          |

|       | Pin Name    | Type | MFP   | Description                                 |
|-------|-------------|------|-------|---------------------------------------------|
|       | UART4_TXD   | O    | MFP7  | UART4 data transmitter output pin.          |
|       | UART0_TXD   | O    | MFP8  | UART0 data transmitter output pin.          |
| PH.11 | PH.11       | I/O  | MFP0  | General purpose digital I/O pin.            |
|       | EBI_AD15    | I/O  | MFP2  | EBI address/data bus bit 15.                |
|       | QSPI0_MOSI1 | I/O  | MFP3  | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|       | UART4_RXD   | I    | MFP7  | UART4 data receiver input pin.              |
|       | UART0_RXD   | I    | MFP8  | UART0 data receiver input pin.              |
|       | EPWM0_CH5   | I/O  | MFP11 | EPWM0 channel 5 output/capture input.       |

## 5 BLOCK DIAGRAM

### 5.1 NuMicro® M480 Block Diagram



Figure 5.1-1 NuMicro® M480 Block Diagram

## 6 FUNCTIONAL DESCRIPTION

### 6.1 ARM® Cortex®-M4 Core

The Cortex®-M4 processor, a configurable, multistage, 32-bit RISC processor, has three AMBA AHB-Lite interfaces for best parallel performance and includes an NVIC component. The processor with optional hardware debug functionality can execute Thumb code and is compatible with other Cortex-M profile processors. The profile supports two modes -Thread mode and Handler mode. Handler mode is entered as a result of an exception. An exception return can only be issued in Handler mode. Thread mode is entered on Reset, and can be entered as a result of an exception return. The Cortex®-M4F is a processor with the same capability as the Cortex®-M4 processor and includes floating point arithmetic functionality. The NuMicro® M480 series is embedded with Cortex®-M4F processor. Throughout this document, the name Cortex®-M4 refers to both Cortex®-M4 and Cortex®-M4F processors. Figure 6.1-1 shows the functional controller of the processor.



Figure 6.1-1 Cortex®-M4 Block Diagram

#### Cortex®-M4 processor features:

- A low gate count processor core, with low latency interrupt processing that has:
  - A subset of the Thumb instruction set, defined in the *ARMv7-M Architecture Reference Manual*
  - Banked Stack Pointer (SP)
  - Hardware integer divide instructions, SDIV and UDIV
  - Handler and Thread modes

- Thumb and Debug states
- Support for interruptible-continued instructions LDM, STM, PUSH, and POP for low interrupt latency
- Automatic processor state saving and restoration for low latency *Interrupt Service Routine (ISR)* entry and exit
- Support for ARMv6 big-endian byte-invariant or little-endian accesses
- Support for ARMv6 unaligned accesses
- Floating Point Unit (FPU) in the Cortex®-M4F processor providing:
  - 32-bit instructions for single-precision (C float) data-processing operations
  - Combined Multiply and Accumulate instructions for increased precision (Fused MAC)
  - Hardware support for conversion, addition, subtraction, multiplication with optional accumulate, division, and square-root
  - Hardware support for denormals and all IEEE rounding modes
  - 32 dedicated 32-bit single precision registers, also addressable as 16 double-word registers
  - Decoupled three stage pipeline
- Nested Vectored Interrupt Controller (NVIC) closely integrated with the processor core to achieve low latency interrupt processing. Features include:
  - External interrupts. Configurable from 1 to 240 (the NuMicro® M480 series configured with 64 interrupts)
  - Bits of priority, configurable from 3 to 8
  - Dynamic reprioritization of interrupts
  - Priority grouping which enables selection of preempting interrupt levels and nonpreempting interrupt levels
  - Support for tril-chaining and late arrival of interrupts, which enables back-to-back interrupt processing without the overhead of state saving and restoration between interrupts.
  - Processor state automatically saved on interrupt entry, and restored on interrupt exit with no instruction overhead
  - Support for Wake-up Interrupt Controller (WIC) with Ultra-low Power Sleep mode
- Memory Protection Unit (MPU). An optional MPU for memory protection, including:
  - Eight memory regions
  - Sub Region Disable (SRD), enabling efficient use of memory regions
  - The ability to enable a background region that implements the default memory map attributes
- Low-cost debug solution that features:
  - Debug access to all memory and registers in the system, including access to memory mapped devices, access to internal core registers when the core is halted, and access to debug control registers even while SYSRESETn is asserted.
  - Serial Wire Debug Port(SW-DP) or Serial Wire JTAG Debug Port (SWJ-DP) debug access
  - Optional Flash Patch and Breakpoint (FPB) unit for implementing breakpoints and

code patches

- Optional Data Watchpoint and Trace (DWT) unit for implementing watchpoints, data tracing, and system profiling
- Optional Instrumentation Trace Macrocell (ITM) for support of printf() style debugging
- Optional Trace Port Interface Unit (TPIU) for bridging to a Trace Port Analyzer (TPA), including Single Wire Output (SWO) mode
- Optional Embedded Trace Macrocell (ETM) for instruction trace.
- Bus interfaces:
  - Three Advanced High-performance Bus-Lite (AHB-Lite) interfaces: ICode, Dcode, and System bus interfaces
  - Private Peripheral Bus (PPB) based on Advanced Peripheral Bus (APB) interface
  - Bit-band support that includes atomic bit-band write and read operations.
  - Memory access alignment
  - Write buffer for buffering of write data
  - Exclusive access transfers for multiprocessor systems

## 6.2 System Manager

### 6.2.1 Overview

System management includes the following sections:

- System Reset
- System Power Distribution
- SRAM Memory Organization
- 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
  - Watchdog Time-out Reset and Window Watchdog Reset (WDT/WWDT Reset)
  - Low Voltage Reset (LVR)
  - Brown-out Detector Reset (BOD Reset)
  - CPU Lockup Reset
- Software Reset Sources
  - CHIP Reset will reset whole chip by writing 1 to CHIPRST (SYS\_IPRST0[0])
  - MCU Reset to reboot but keeping the booting setting from APROM or LDROM by writing 1 to SYSRESETREQ (AIRCR[2])
  - CPU Reset for Cortex®-M4 core only by writing 1 to CPURST (SYS\_IPRST0[1])



Figure 6.2-1 System Reset Sources

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

| Reset Sources Register          | POR                 | NRESET              | WDT                 | LVR                 | BOD                 | Lockup              | CHIP                | MCU                 | CPU       |
|---------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|-----------|
| <b>SYS_RSTSTS</b>               | Bit 0 = 1           | Bit 1 = 1           | Bit 2 = 1           | Bit 3 = 1           | Bit 4 = 1           | Bit 8 = 1           | Bit 0 = 1           | Bit 5 = 1           | Bit 7 = 1 |
| <b>CHIPRST (SYS_IPRST0[0])</b>  | 0x0                 | -                   | -                   | -                   | -                   | -                   | -                   | -                   | -         |
| <b>BODEN (SYS_BODCTL[0])</b>    | Reload from CONFIG0 | Reload from CONFIG0 | Reload from CONFIG0 | Reload from CONFIG0 | -                   | Reload from CONFIG0 | Reload from CONFIG0 | -                   | -         |
| <b>BODVL (SYS_BODCTL[2:1])</b>  |                     |                     |                     |                     |                     |                     |                     |                     |           |
| <b>BODRSTEN (SYS_BODCTL[3])</b> |                     |                     |                     |                     |                     |                     |                     |                     |           |
| <b>HXTEN (CLK_PWRCTL[0])</b>    | Reload from CONFIG0 | -         |
| <b>LXTEN (CLK_PWRCTL[1])</b>    | 0x0                 | -                   | -                   | -                   | -                   | -                   | -                   | -                   | -         |
| <b>WDTCKEN (CLK_APBCLK0[0])</b> | 0x1                 | -                   | 0x1                 | -                   | -                   | -                   | 0x1                 | -                   | -         |
| <b>HCLKSEL</b>                  | Reload from         | -         |

|                                                                           |                        |                        |                        |                        |                        |         |                        |         |   |
|---------------------------------------------------------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|---------|------------------------|---------|---|
| (CLK_CLKSEL0[2:0])                                                        | CONFIG0                | CONFIG0                | CONFIG0                | CONFIG0                | CONFIG0                | CONFIG0 | CONFIG0                | CONFIG0 |   |
| WDTSEL<br>(CLK_CLKSEL1[1:0])                                              | 0x3                    | 0x3                    | -                      | -                      | -                      | -       | -                      | -       | - |
| HXTSTB<br>(CLK_STATUS[0])                                                 | 0x0                    | -                      | -                      | -                      | -                      | -       | -                      | -       | - |
| LXTSTB<br>(CLK_STATUS[1])                                                 | 0x0                    | -                      | -                      | -                      | -                      | -       | -                      | -       | - |
| PLLSTB<br>(CLK_STATUS[2])                                                 | 0x0                    | -                      | -                      | -                      | -                      | -       | -                      | -       | - |
| HIRCSTB<br>(CLK_STATUS[4])                                                | 0x0                    | -                      | -                      | -                      | -                      | -       | -                      | -       | - |
| CLKSFAIL<br>(CLK_STATUS[7])                                               | 0x0                    | 0x0                    | -                      | -                      | -                      | -       | -                      | -       | - |
| RSTEN<br>(WDT_CTL[1])                                                     | Reload from CONFIG0    | -       | Reload from CONFIG0    | -       | - |
| WDTEN<br>(WDT_CTL[7])                                                     |                        | Reload from CONFIG0    | Reload from CONFIG0    | Reload from CONFIG0    | Reload from CONFIG0    |         | Reload from CONFIG0    |         |   |
| WDT_CTL<br>except bit 1 and bit 7.                                        | 0x0700                 | 0x0700                 | 0x0700                 | 0x0700                 | 0x0700                 | -       | 0x0700                 | -       | - |
| WDT_ALTCTL                                                                | 0x0000                 | 0x0000                 | 0x0000                 | 0x0000                 | 0x0000                 | -       | 0x0000                 | -       | - |
| WWDT_RLDCNT                                                               | 0x0000                 | 0x0000                 | 0x0000                 | 0x0000                 | 0x0000                 | -       | 0x0000                 | -       | - |
| WWDT_CTL                                                                  | 0x3F0800               | 0x3F0800               | 0x3F0800               | 0x3F0800               | 0x3F0800               | -       | 0x3F0800               | -       | - |
| WWDT_STATUS                                                               | 0x0000                 | 0x0000                 | 0x0000                 | 0x0000                 | 0x0000                 | -       | 0x0000                 | -       | - |
| WWDT_CNT                                                                  | 0x3F                   | 0x3F                   | 0x3F                   | 0x3F                   | 0x3F                   | -       | 0x3F                   | -       | - |
| BS<br>(FMC_ISPCTL[1])                                                     | Reload from CONFIG0    | -       | Reload from CONFIG0    | -       | - |
| BL<br>(FMC_ISPCTL[16])                                                    |                        | Reload from CONFIG0    | Reload from CONFIG0    | Reload from CONFIG0    | Reload from CONFIG0    |         | Reload from CONFIG0    |         |   |
| FMC_DFBA                                                                  | Reload from CONFIG1    | -       | Reload from CONFIG1    | -       | - |
| CBS<br>(FMC_ISPSTS[2:1])                                                  | Reload from CONFIG0    | -       | Reload from CONFIG0    | -       | - |
| VECMAP<br>(FMC_ISPSTS[23:9])                                              | Reload base on CONFIG0 | -       | Reload base on CONFIG0 | -       | - |
| Other Peripheral Registers                                                | Reset Value            |                        |                        |                        |                        |         |                        | -       |   |
| FMC Registers                                                             | Reset Value            |                        |                        |                        |                        |         |                        |         |   |
| <b>Note:</b> '-' means that the value of register keeps original setting. |                        |                        |                        |                        |                        |         |                        |         |   |

Table 6.2-1 Reset Value of Registers

### 6.2.2.1 nRESET Reset

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



Figure 6.2-2 nRESET Reset Waveform

### 6.2.2.2 Power-on Reset (POR)

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



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

### 6.2.2.3 Low Voltage Reset (LVR)

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

$AV_{DD}$  voltage rises above  $V_{LVR}$  and the state keeps longer than De-glitch time set by LVRDGSEL (SYS\_BODCTL[14:12]). The default setting of Low Voltage Reset is enabled without De-glitch function. Figure 6.2-4 shows the Low Voltage Reset waveform.



Figure 6.2-4 Low Voltage Reset (LVR) Waveform

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

If the Brown-out Detector (BOD) function is enabled by setting the Brown-out Detector Enable Bit BODEN (SYS\_BODCTL[0]), Brown-out Detector function will detect  $AV_{DD}$  during system operation. When the  $AV_{DD}$  voltage is lower than  $V_{BOD}$  which is decided by BODEN 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  $AV_{DD}$  voltage rises above  $V_{BOD}$  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 (CONFIG0 [19]), CBOV (CONFIG0 [23:21]) and CBORST(CONFIG0[20]) respectively. User can determine the initial BOD setting by setting the CONFIG0 register. Figure 6.2-5 shows the Brown-out Detector waveform.



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

#### 6.2.2.5 Watchdog Timer Reset (WDT)

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

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

#### 6.2.2.6 CPU Lockup Reset

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

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

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

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

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

### 6.2.3 System Power Distribution

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

- Analog power from AV<sub>DD</sub> and AV<sub>SS</sub> provides the power for analog components operation.
- Digital power from V<sub>DD</sub> and V<sub>SS</sub> supplies the power to the internal regulator which provides a fixed 1.8 V power for digital operation and I/O pins.
- USB transceiver power from VBUS offers the power for operating the USB transceiver.
- RTC power from V<sub>DD</sub> provides the power for RTC and 80 bytes backup registers.

The outputs of internal voltage regulators, LDO and VDD33, require an external capacitor which should be located close to the corresponding pin. Analog power (AV<sub>DD</sub>) should be the same voltage level of the digital power (V<sub>DD</sub>). Figure 6.2-6 shows the NuMicro® M480 power distribution.



Figure 6.2-6 NuMicro® M480 Power Distribution Diagram

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

The NuMicro® M480 series has power manager unit to support several operating modes for saving power. Table 6.2-2 lists all power modes in the NuMicro® M480 series.

| Mode                                            | CPU Operating Maximum Speed (MHz) | LDO_CAP (V) | Clock Disable                                                                                                                                         |
|-------------------------------------------------|-----------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Normal mode                                     | 160                               | 1.20        | All clocks are disabled by control register.                                                                                                          |
| Turbo mode                                      | 192                               | 1.26        | All clocks are disabled by control register.                                                                                                          |
| Idle mode                                       | CPU enter Sleep mode              | 1.20/1.26   | Only CPU clock is disabled.                                                                                                                           |
| Fast Wakeup Power-down mode (FWPD)              | CPU enters Deep Sleep mode        | 1.20/1.26   | Most clocks are disabled except LIRC/LXT, and only RTC/WDT/Timer/UART peripheral clocks still enable if their clock sources are selected as LIRC/LXT. |
| Normal Power-down mode (NPD)                    | CPU enters Deep Sleep mode        | 1.20/1.26   | Most clocks are disabled except LIRC/LXT, and only RTC/WDT/Timer/UART peripheral clocks still enable if their clock sources are selected as LIRC/LXT. |
| Low leakage Power-down mode (LLPD)              | CPU enters Deep Sleep mode        | 0.9         | Most clocks are disabled except LIRC/LXT, and only RTC/WDT/Timer/UART peripheral clocks still enable if their clock sources are selected as LIRC/LXT. |
| Standby Power-down mode 0 (SPD0) <sup>[1]</sup> | Power off                         | Floating    | Only LIRC/LXT still enable for RTC function and wake-up timer usage                                                                                   |
| Standby Power-down mode 1 (SPD1) <sup>[1]</sup> | Power off                         | Floating    | Only LIRC/LXT still enable for RTC function and wake-up timer usage                                                                                   |
| Deep Power-down mode (DPD)                      | Power off                         | Floating    | Only LIRC still enable for wake-up timer usage                                                                                                        |

Table 6.2-2 Power Mode Table

**Note:**<sup>[1]</sup>

User must turn on LIRC before entering SPD0/1 mode.

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 as 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 Mode   | SLEEPDEEP (SCR[2]) | PDEN (CLK_PWRCTL[7]) | PDMSEL (CLK_PMUCTL[2:0]) | CPU Run WFI Instruction |
|-----------------------------|--------------------|----------------------|--------------------------|-------------------------|
| Normal mode                 | 0                  | 0                    | 0                        | NO                      |
| Idle mode                   | 0                  | 0                    | 0                        | YES                     |
| Fast Wakeup Power-down mode | 1                  | 1                    | 2                        | YES                     |
| Normal Power-down mode      | 1                  | 1                    | 0                        | YES                     |
| Low leakage Power-down mode | 1                  | 1                    | 1                        | YES                     |

|                           |   |   |   |     |
|---------------------------|---|---|---|-----|
| Standby Power-down mode 0 | 1 | 1 | 4 | YES |
| Standby Power-down mode 1 | 1 | 1 | 5 | YES |
| Deep Power-down 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                                                                       |
|-------------------------|----------------------------------------------------|-------------------------------|---------------------------------------------------------------------------------------|
| <b>Definition</b>       | CPU is in active state                             | CPU is in sleep state         | CPU is in sleep state and all clocks stop except LXT and LIRC. SRAM content retained. |
| <b>Entry Condition</b>  | Chip is in normal mode after system reset released | CPU executes WFI instruction. | CPU sets sleep mode enable and power down enable and executes WFI instruction.        |
| <b>Wake-up Sources</b>  | N/A                                                | All interrupts                | RTC, WDT, I <sup>2</sup> C, Timer, UART, BOD, GPIO, EINT, USCI, USBD, ACMP and BOD.   |
| <b>Available Clocks</b> | All                                                | All except CPU clock          | LXT and LIRC                                                                          |
| <b>After Wake-up</b>    | N/A                                                | CPU back to normal mode       | CPU back to normal mode                                                               |

Table 6.2-4 Power Mode Definition Table



Figure 6.2-7 Power Mode State Machine

|      | Idle Mode | NPD, LLPD, FWPD       | SPD0, SPD1,           | DPD                   |
|------|-----------|-----------------------|-----------------------|-----------------------|
| HXT  | ON        | Halt                  | Halt                  | Halt                  |
| HIRC | ON        | Halt                  | Halt                  | Halt                  |
| LXT  | ON        | ON/OFF <sup>[1]</sup> | ON/OFF <sup>[1]</sup> | Halt                  |
| LIRC | ON        | ON/OFF <sup>[2]</sup> | ON/OFF <sup>[2]</sup> | ON/OFF <sup>[2]</sup> |

|                |      |                       |                       |      |
|----------------|------|-----------------------|-----------------------|------|
| PLL            | ON   | Halt                  | Halt                  | Halt |
| HCLK/PCLK      | ON   | Halt                  | Halt                  | Halt |
| CPU            | Halt | Halt                  | Halt                  | Halt |
| SRAM retention | ON   | ON                    | Halt                  | Halt |
| FLASH          | Halt | Halt                  | Halt                  | Halt |
| TIMER          | ON   | ON/OFF <sup>[3]</sup> | ON/OFF <sup>[3]</sup> | Halt |
| WDT            | ON   | ON/OFF <sup>[4]</sup> | Halt                  | Halt |
| RTC            | ON   | ON/OFF <sup>[5]</sup> | ON/OFF <sup>[5]</sup> | Halt |
| UART           | ON   | ON/OFF <sup>[6]</sup> | Halt                  | Halt |
| Others         | ON   | Halt                  | Halt                  | Halt |

Table 6.2-5 Clocks in Power Modes

**Note:**

1. LXT ON or OFF depends on SW setting in normal mode.
2. LIRC ON or OFF depends on S/W setting in normal mode.
3. If TIMER clock source is selected as LIRC/LXT and LIRC/LXT is on.
4. If WDT clock source is selected as LIRC and LIRC is on.
5. If RTC clock source is selected as LXT and LXT is on.
6. If UART clock source is selected as LXT and LXT is on.

**Wake-up sources in Normal Power-down mode (NPD):**

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

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

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

| Wake-Up Source | Wake-Up Condition                    | Power-Down Mode       |        |     | Re-Entering Power-Down Mode Condition                                             |
|----------------|--------------------------------------|-----------------------|--------|-----|-----------------------------------------------------------------------------------|
|                |                                      | NPD/<br>FWPD/<br>LLPD | SPD0/1 | DPD |                                                                                   |
| BOD            | Brown-Out Detector Reset / Interrupt | V                     | -      | -   | After software writes 1 to clear BODIF (SYS_BODCTL[4]).                           |
|                | Brown-Out Detector Reset             | -                     | V      | -   | After software writes 1 to clear BODWK (CLK_PMUSTS[13]) when SPD mode is entered. |
| LVR            | LVR Reset                            | V                     | -      | -   | After software writes 1 to clear LVRF (SYS_RSTSTS[3])                             |
|                |                                      | -                     | V      | -   | After software writes 1 to clear LVRWK (CLK_PMUSTS[12]) when SPD mode is entered. |
| POR            | POR Reset                            | V                     | V      | -   | After software writes 1 to clear PORF (SYS_RSTSTS[0])                             |

|                            |                                                |   |   |   |                                                                                                                     |
|----------------------------|------------------------------------------------|---|---|---|---------------------------------------------------------------------------------------------------------------------|
| INT                        | External Interrupt                             | V | - | - | After software write 1 to clear the Px_INTSRC[n] bit.                                                               |
| GPIO                       | GPIO Interrupt                                 | V | - | - | After software write 1 to clear the Px_INTSRC[n] bit.                                                               |
| GPIO(PA~PD)<br>Wake-up pin | rising or falling edge<br>event, 64-pin        | - | V | - | After software writes 1 to clear GPxWK<br>(CLK_PMUSTS[11:8]) when SPD mode is entered.                              |
| GPIO(PC.0)<br>Wake-up pin  | rising or falling edge<br>event , 1-pin        | - | - | V | After software writes 1 to clear PINWK<br>(CLK_PMUSTS[1]) when DPD mode is entered.                                 |
| TIMER                      | Timer Interrupt                                | V | - | - | After software writes 1 to clear TWKF<br>(TIMERx_INTSTS[1]) and TIF (TIMERx_INTSTS[0]).                             |
| Wakeup timer               | Wakeup by wake-up<br>timer time-out            | - | V | V | After software writes 1 to clear TMRWK<br>(CLK_PMUSTS[1]) when SPD or DPD mode is entered.                          |
| WDT                        | WDT Interrupt                                  | V | - | - | After software writes 1 to clear WKF (WDT_CTL[5])<br>(Write Protect).                                               |
| RTC                        | Alarm Interrupt                                | V | - | - | After software writes 1 to clear ALMIF<br>(RTC_INTSTS[0]).                                                          |
|                            | Time Tick Interrupt                            | V | - | - | After software writes 1 to clear TICKIF<br>(RTC_INTSTS[1]).                                                         |
|                            | Wakeup by RTC alarm                            | - | V | - | After software writes 1 to clear RTCWK<br>(CLK_PMUSTS[2]) when SPD mode is entered.                                 |
|                            | Wakeup by RTC tick<br>time                     | - | V | - | After software writes 1 to clear RTCWK<br>(CLK_PMUSTS[2]) when SPD mode is entered.                                 |
|                            | Wakeup by tamper<br>event                      | - | V | - | After software writes 1 to clear RTCWK<br>(CLK_PMUSTS[2]) when SPD mode is entered.                                 |
| UART                       | nCTS wake-up                                   | V | - | - | After software writes 1 to clear CTSWKF<br>(UARTx_WKSTS[0]).                                                        |
|                            | RX Data wake-up                                | V | - | - | After software writes 1 to clear DATWKF<br>(UARTx_WKSTS[1]).                                                        |
|                            | Received FIFO<br>Threshold Wake-up             | V | - | - | After software writes 1 to clear RFRTWKF<br>(UARTx_WKSTS[2]).                                                       |
|                            | RS-485 AAD Mode<br>Wake-up                     | V | - | - | After software writes 1 to clear RS485WKF<br>(UARTx_WKSTS[3]).                                                      |
|                            | Received FIFO<br>Threshold Time-out<br>Wake-up | V | - | - | After software writes 1 to clear TOUTWKF<br>(UARTx_WKSTS[4]).                                                       |
| USCI UART                  | CTS Toggle                                     | V | - | - | After software writes 1 to clear WKF<br>(UUART_WKSTS[0]).                                                           |
|                            | Data Toggle                                    | V | - | - | After software writes 1 to clear WKF<br>(UUART_WKSTS[0]).                                                           |
| USCI I2C                   | Data toggle                                    | V | - | - | After software writes 1 to clear WKF<br>(UI2C_WKSTS[0]).                                                            |
|                            | Address match                                  | V | - | - | After software writes 1 to clear WKAKDONE<br>(UI2C_PROTSTS[16], then writes 1 to clear WKF<br>(UI2C_WKSTS[0]).      |
| USCI SPI                   | SS Toggle                                      | V | - | - | After software writes 1 to clear WKF<br>(USPI_WKSTS[0]).                                                            |
| I <sup>2</sup> C           | Address match wake-up                          | V | - | - | After software writes 1 to clear WKAKDONE<br>(I2C_WKSTS[1]). Then software writes 1 to clear<br>WKIF(I2C_WKSTS[0]). |

|      |                                         |   |   |   |                                                                                     |
|------|-----------------------------------------|---|---|---|-------------------------------------------------------------------------------------|
| USBD | Remote Wake-up                          | V | - | - | After software writes 1 to clear BUSIF (USBD_INTSTS[0]).                            |
| ACMP | Comparator Power-Down Wake-Up Interrupt | V | - | - | After software writes 1 to clear WKIF0 (ACMP_STATUS[8]) and WKIF1 (ACMP_STATUS[9]). |
| ACMP | ACMPO status change                     | - | V | - | After software writes 1 to clear ACMPWK (CLK_PMUSTS[14]) when SPD mode is entered.  |

Table 6.2-6 Re-Entering Power-down Mode Condition

### 6.2.5 Power Modes and Power Level Transition



Figure 6.2-8 NuMicro® M480 Power Distribution Diagram

### 6.2.6 System Memory Map

The NuMicro® M480 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 NuMicro®

M480 series only supports little-endian data format.

| Address Space                                                   | Token     | Controllers                                                     |
|-----------------------------------------------------------------|-----------|-----------------------------------------------------------------|
| <b>Flash and SRAM Memory Space</b>                              |           |                                                                 |
| 0x0000_0000 – 0x0003_FFFF                                       | FLASH_BA  | FLASH Memory Space (256KB)                                      |
| 0x0000_0000 – 0x0007_FFFF                                       | FLASH_BA  | FLASH Memory Space (512KB)                                      |
| 0x0800_0000 – 0x09FF_FFFF                                       | SPIM_BA   | SPIM Memory Space (32MB)                                        |
| 0x2000_0000 – 0x2000_7FFF                                       | SRAM0_BA  | SRAM Memory Space (32KB)                                        |
| 0x2000_8000 – 0x2001_FFFF                                       | SRAM1_BA  | SRAM Memory Space (96KB)                                        |
| 0x2002_0000 – 0x2002_7FFF                                       | SRAM2_BA  | SRAM Memory Space (32KB) for CPU only and share with SPIM cache |
| 0x6000_0000 – 0x6FFF_FFFF                                       | EXTMEM_BA | External Memory Space (256MB)                                   |
| <b>Peripheral Controllers Space (0x4000_0000 – 0x400F_FFFF)</b> |           |                                                                 |
| 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_7000 – 0x4000_7FFF                                       | SPIM_BA   | SPIM Control Registers                                          |
| 0x4000_8000 – 0x4000_8FFF                                       | PDMA_BA   | Peripheral DMA Control Registers                                |
| 0x4000_9000 – 0x4000_9FFF                                       | USBH_BA   | USB Host Control Registers                                      |
| 0x4000_B000 – 0x4000_BFFF                                       | EMAC_BA   | Ethernet MAC Control Registers                                  |
| 0x4000_C000 – 0x4000_CFFF                                       | FMC_BA    | Flash Memory Control Registers                                  |
| 0x4000_D000 – 0x4000_DFFF                                       | SDH0_BA   | SDHOST0 Control Registers                                       |
| 0x4000_E000 – 0x4000_EFFF                                       | SDH1_BA   | SDHOST1 Control Registers                                       |
| 0x4001_0000 – 0x4001_0FFF                                       | EBI_BA    | External Bus Interface Control Registers                        |
| 0x4001_9000 – 0x4001_9FFF                                       | HSUSBD_BA | HSUSBD Control Registers                                        |
| 0x4001_A000 – 0x4001_AFFF                                       | HSUSBH_BA | HSUSBH Host Control Registers                                   |
| 0x4003_1000 – 0x4003_1FFF                                       | CRC_BA    | CRC Generator Registers                                         |
| 0x4003_E000 – 0x4003_EFFF                                       | SWDC_BA   | SWD Control Registers                                           |
| 0x4003_F000 – 0x4003_FFFF                                       | ETMC_BA   | ETM Control Registers                                           |
| 0x5008_0000 – 0x5008_0FFF                                       | CRYP_BA   | Cryptographic Accelerator Registers                             |
| <b>APB Controllers Space (0x4000_0000 ~ 0x400F_FFFF)</b>        |           |                                                                 |
| 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                         |
| 0x4004_8000 – 0x4004_8FFF | I2S0_BA  | I <sup>2</sup> S0 Interface Control Registers |
| 0x4004_D000 – 0x4004_DFFF | OTG_BA   | OTG Control Registers                         |
| 0x4004_F000 – 0x4004_FFFF | HSOTG_BA | HSOTG 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 | EPWM0_BA | EPWM0 Control Registers                       |
| 0x4005_9000 – 0x4005_9FFF | EPWM1_BA | EPWM1 Control Registers                       |
| 0x4005_A000 – 0x4005_AFFF | BPWM0_BA | BPWM0 Control Registers                       |
| 0x4005_B000 – 0x4005_BFFF | BPWM1_BA | BPWM1 Control Registers                       |
| 0x4006_0000 – 0x4006_0FFF | QSPI0_BA | QSPI0 Control Registers                       |
| 0x4006_1000 – 0x4006_1FFF | SPI0_BA  | SPI0 Control Registers                        |
| 0x4006_2000 – 0x4006_2FFF | SPI1_BA  | SPI1 Control Registers                        |
| 0x4006_3000 – 0x4006_3FFF | SPI2_BA  | SPI2 Control Registers                        |
| 0x4006_4000 – 0x4006_4FFF | SPI3_BA  | SPI3 Control Registers                        |
| 0x4007_0000 – 0x4007_0FFF | UART0_BA | UART0 Control Registers                       |
| 0x4007_1000 – 0x4007_1FFF | UART1_BA | UART1 Control Registers                       |
| 0x4007_2000 – 0x4007_2FFF | UART2_BA | UART2 Control Registers                       |
| 0x4007_3000 – 0x4007_3FFF | UART3_BA | UART3 Control Registers                       |
| 0x4007_4000 – 0x4007_4FFF | UART4_BA | UART4 Control Registers                       |
| 0x4007_5000 – 0x4007_5FFF | UART5_BA | UART5 Control Registers                       |
| 0x4008_0000 – 0x4008_0FFF | I2C0_BA  | I <sup>2</sup> C0 Control Registers           |
| 0x4008_1000 – 0x4008_1FFF | I2C1_BA  | I <sup>2</sup> C1 Control Registers           |
| 0x4008_2000 – 0x4008_2FFF | I2C2_BA  | I <sup>2</sup> C2 Control Registers           |
| 0x4009_0000 – 0x4009_0FFF | SC0_BA   | Smartcard Host 0 Control Registers            |
| 0x4009_1000 – 0x4009_1FFF | SC1_BA   | Smartcard Host 1 Control Registers            |
| 0x4009_2000 – 0x4009_2FFF | SC2_BA   | Smartcard Host 2 Control Registers            |
| 0x4009_3000 – 0x4009_3FFF | SC3_BA   | Smartcard Host 3 Control Registers            |
| 0x400A_0000 – 0x400A_0FFF | CAN0_BA  | CAN0 Bus Control Registers                    |
| 0x400A_1000 – 0x400A_1FFF | CAN1_BA  | CAN1 Bus Control Registers                    |
| 0x400B_0000 – 0x400B_0FFF | QEI0_BA  | QEI0 Control Registers                        |
| 0x400B_1000 – 0x400B_1FFF | QEI1_BA  | QEI1 Control Registers                        |
| 0x400B_4000 – 0x400B_4FFF | ECAP0_BA | ECAP0 Control Registers                       |
| 0x400B_5000 – 0x400B_5FFF | ECAP1_BA | ECAP1 Control Registers                       |
| 0x400C_0000 – 0x400C_0FFF | USBD_BA  | USB Device Control Register                   |

|                                                             |          |                                                 |
|-------------------------------------------------------------|----------|-------------------------------------------------|
| 0x400D_0000 – 0x400D_0FFF                                   | USCI0_BA | USCI0 Control Registers                         |
| 0x400D_1000 – 0x400D_1FFF                                   | USCI1_BA | USCI1 Control Registers                         |
| <b>System Controllers Space (0xE000_E000 ~ 0xE000_EFFF)</b> |          |                                                 |
| 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 Organization

The M480 series supports embedded SRAM with total 160 Kbytes size and the SRAM organization is separated to three banks: SRAM bank0 and SRAM bank1 and SRAM bank2. The first bank has 32 Kbytes address space, the second bank has 96 Kbytes address space and the third bank has 32Kbytes. These three banks address space can be accessed simultaneously. The SRAM bank0 supports parity error check to make sure chip operating more stable. The SRAM bank2 is shared with SPIM cache, and it can switch to external SPI Flash cache memory. Note that SRAM bank2 has additional two wait cycles when reading data.

- Supports total 160 Kbytes SRAM
- Supports byte / half word / word write
- Supports fixed 32 Kbytes SRAM bank0 for independent access
- Supports parity error check function for SRAM bank0
- Supports oversize response error
- Supports remap address to 0x1000\_0000



Figure 6.2-9 SRAM Block Diagram

Figure 6.2-9 shows the SRAM organization of M480. There are three SRAM banks in M480. The bank0 is addressed to 32 Kbytes, the bank1 is addressed to 96 Kbytes and the bank2 is addressed to 32 Kbyte. The bank0 address space is from 0x2000\_0000 to 0x2000\_7FFF. The bank1 address space is from 0x2000\_8000 to 0x2001\_FFFF. The bank2 address space is from 0x2002\_0000 to 0x2002\_7FFF. The address between 0x2002\_8000 to 0x3FFF\_FFFF is illegal memory space and chip will enter hardfault if CPU accesses these illegal memory addresses.

|            | 160 KB Device                                             | 96KB Device                                               | Read access                           |
|------------|-----------------------------------------------------------|-----------------------------------------------------------|---------------------------------------|
| SRAM bank0 | 0x2000_0000 ~ 0x2000_7FFF<br>or 0x1000_0000 ~ 0x1000_7FFF | 0x2000_0000 ~ 0x2000_7FFF<br>or 0x1000_0000 ~ 0x1000_7FFF | Zero wait cycle for continuous access |
| SRAM bank1 | 0x2000_8000 ~ 0x2001_FFFF<br>or 0x1000_8000 ~ 0x1001_FFFF | 0x2000_8000 ~ 0x2000_FFFF<br>or 0x1000_8000 ~ 0x1000_FFFF | Zero wait cycle for continuous access |
| SRAM bank2 | 0x2002_0000 ~ 0x2002_7FFF<br>or 0x1002_0000 ~ 0x1002_7FFF | 0x2001_0000 ~ 0x2001_7FFF<br>or 0x1001_0000 ~ 0x1001_7FFF | Two wait cycles                       |

Table 6.2-8 SRAM Organization

The address of each bank is remapping from 0x2000\_0000 to 0x1000\_0000. CPU can access SRAM bank0 through 0x2000\_0000 to 0x2000\_7FFF or 0x1000\_0000 to 0x1000\_7FFF, and access SRAM bank1 through 0x2000\_8000 to 0x2001\_FFFF or 0x1000\_8000 to 0x1001\_FFFF, and access SRAM bank2 through 0x2002\_0000 to 0x2002\_7FFF or 0x1002\_0000 to 0x1002\_7FFF.

When setting the control register CCMEN(SPI\_M\_CTL1[2]) to 0, SRAM bank2 is switched to external SPI Flash cache memory. In this case, the SRAM bank2 can't be accessed as gernal SRAM. If user access SRAM bank2 by AHB bus master, the SPI flash controller will send error response via HRESP AHB bus signal to bus master.



Figure 6.2-10 SRAM Memory Organization

SRAM bank0 has byte parity error check function. When CPU is accessing SRAM bank0, the parity error checking mechanism is dynamic operating. As parity error occurred, the PERRIF (SYS\_SRAM\_STATUS[0]) will be asserted to 1 and the SYS\_SRAM\_ERRADDR register will recode the address with parity error. Chip will enter interrupt when SRAM parity error occurred if PERRIEN (SYS\_SRAM\_INTCTL[0]) is set to 1. When SRAM parity error occurred, chip will stop detecting SRAM parity error until user writes 1 to clear the PERRIF(SYS\_SRAM\_STATUS[0]) bit.

### 6.2.8 Bus Matrix

The M480 series supports Bus Matrix to manage the access arbitration between masters. The access arbitration can be selected by INTACTEN (SYS\_AHBMCTL[0]) to use round-robin algorithm or set Cortex®-M4 CPU as the highest bus priority.



Figure 6.2-11 NuMicro® M480 Bus Matrix Diagram

### 6.2.9 HIRC Auto Trim

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

For instance, the system needs an accurate 12 MHz clock. In such case, if neither using PLL as the system clock source nor soldering 32.768 kHz crystal in system, user has to set REFCKSEL (SYS\_IRCTCTL[10] reference clock selection) to “1”, set FREQSEL (SYS\_IRCTCTL[1:0] trim frequency selection) to “01”, and the auto-trim function will be enabled. Interrupt status bit FREQLOCK (SYS\_IRCTISTS[8] HIRC frequency lock status) “1” indicates the HIRC output frequency is accurate within 0.25% deviation.

### 6.2.10 Register Lock Control

Some of the system control registers need to be protected to avoid inadvertent write and disturb the chip operation. These system control registers are protected after the power-on reset till user to disable register protection. For user to program these protected registers, a register protection disable sequence needs to be followed by a special programming. The register protection disable sequence is writing the data “59h”, “16h” “88h” to the register SYS\_REGLCTL address at 0x4000\_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.

|                  |                     |
|------------------|---------------------|
| SYS_IPRST0       | Address 0x4000_0008 |
| SYS_ALTCTL       | address 0x4000_0014 |
| SYS_BODCTL       | address 0x4000_0018 |
| SYS_PORCTL       | address 0x4000_0024 |
| SYS_VREFCTL      | address 0x4000_0028 |
| SYS_USBPHY       | address 0x4000_002C |
| SYS_SRAM_BISTCTL | address 0x4000_00D0 |
| SYS_CVCTL        | address 0x4000_01F8 |
| CLK_PWRCTL       | address 0x4000_0200 |
| CLK_APBCLK0      | address 0x4000_0208 |
| CLK_CLKSEL0      | address 0x4000_0210 |
| CLK_CLKSEL1      | address 0x4000_0214 |
| CLK_PLLCTL       | address 0x4000_0240 |
| CLK_PMUCTL       | address 0x4000_0290 |
| NMIEN            | address 0x4000_0300 |
| AHBMCTL          | address 0x4000_0400 |
| FMC_FTCTL        | address 0x4000_5018 |
| FMC_ICPCMD       | address 0x4000_501C |
| FMC_ISPCTL       | address 0x4000_C000 |
| FMC_ISPTRG       | address 0x4000_C010 |
| FMC_ISPSTS       | address 0x4000_C040 |
| FMC_CYCCTL       | address 0x4000_C04C |
| FMC_KPKEYTRG     | address 0x4000_C05C |
| FMC_KPKEYSTS     | address 0x4000_C060 |
| WDT_CTL          | address 0x4004_0000 |
| WDT_ALTCTL       | address 0x4004_0004 |
| TIMER0_CTL       | address 0x4005_0000 |
| TIMER1_CTL       | address 0x4005_0100 |
| TIMER2_CTL       | address 0x4005_1000 |
| TIMER3_CTL       | address 0x4005_1100 |

|                   |                                 |
|-------------------|---------------------------------|
| TIMER0_PWMCTL     | address 0x4005_0040             |
| TIMER1_PWMCTL     | address 0x4005_0140             |
| TIMER2_PWMCTL     | address 0x4005_1040             |
| TIMER3_PWMCTL     | address 0x4005_1140             |
| TIMER0_PWMMDTCTL  | address 0x4005_0058             |
| TIMER1_PWMMDTCTL  | address 0x4005_0158             |
| TIMER2_PWMMDTCTL  | address 0x4005_1058             |
| TIMER3_PWMMDTCTL  | address 0x4005_1158             |
| TIMER0_PWMBRKCTL  | address 0x4005_0070             |
| TIMER1_PWMBRKCTL  | address 0x4005_0170             |
| TIMER2_PWMBRKCTL  | address 0x4005_1070             |
| TIMER3_PWMBRKCTL  | address 0x4005_1170             |
| TIMER0_PWMSWBRK   | address 0x4005_007C             |
| TIMER1_PWMSWBRK   | address 0x4005_017C             |
| TIMER2_PWMSWBRK   | address 0x4005_107C             |
| TIMER3_PWMSWBRK   | address 0x4005_117C             |
| TIMER0_PWMINTEN1  | address 0x4005_0084             |
| TIMER1_PWMINTEN1  | address 0x4005_0184             |
| TIMER2_PWMINTEN1  | address 0x4005_1084             |
| TIMER3_PWMINTEN1  | address 0x4005_1184             |
| TIMER0_PWMINTSTS1 | address 0x4005_008C             |
| TIMER1_PWMINTSTS1 | address 0x4005_018C             |
| TIMER2_PWMINTSTS1 | address 0x4005_108C             |
| TIMER3_PWMINTSTS1 | address 0x4005_118C             |
| EPWM_CTL0         | address 0x4005_8000/0x4005_9000 |
| EPWM_CTL1         | address 0x4005_8000/0x4005_9000 |
| EPWM_DTCTL0_1     | address 0x4005_8070/0x4005_9070 |
| EPWM_DTCTL2_3     | address 0x4005_8074/0x4005_9074 |
| EPWM_DTCTL4_5     | address 0x4005_8078/0x4005_9078 |
| EPWM_BRKCTL0_1    | address 0x4005_80C8/0x4005_90C8 |
| EPWM_BRKCTL2_3    | address 0x4005_80CC/0x4005_90CC |
| EPWM_BRKCTL4_5    | address 0x4005_80D0/0x4005_90D0 |
| EPWM_SWBRK        | address 0x4005_80DC/0x4005_90DC |
| EPWM_INTEN1       | address 0x4005_80E4/0x4005_90E4 |
| EPWM_INTSTS1      | address 0x4005_80EC/0x4005_90EC |

|           |                                 |
|-----------|---------------------------------|
| BPWM_CTL0 | address 0x4005_A000/0x4005_B000 |
| SYST_VAL  | address 0xE000_E018             |

### 6.2.11 Register Map

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

| Register                    | Offset      | R/W | Description                                        | Reset Value     |
|-----------------------------|-------------|-----|----------------------------------------------------|-----------------|
| <b>SYS Base Address:</b>    |             |     |                                                    |                 |
| <b>SYS_BA = 0x4000_0000</b> |             |     |                                                    |                 |
| <b>SYS_P DID</b>            | SYS_BA+0x00 | R   | Part Device Identification Number Register         | 0x0045_1A93 [1] |
| <b>SYS_RSTSTS</b>           | SYS_BA+0x04 | R/W | System Reset Status Register                       | 0x0000_0043     |
| <b>SYS_IPRST0</b>           | SYS_BA+0x08 | R/W | Peripheral Reset Control Register 0                | 0x0000_0000     |
| <b>SYS_IPRST1</b>           | SYS_BA+0x0C | R/W | Peripheral Reset Control Register 1                | 0x0000_0000     |
| <b>SYS_IPRST2</b>           | SYS_BA+0x10 | R/W | Peripheral Reset Control Register 2                | 0x0000_0000     |
| <b>SYS_BODCTL</b>           | SYS_BA+0x18 | R/W | Brown-Out Detector Control Register                | 0x000X_038X     |
| <b>SYS_IVSCTL</b>           | SYS_BA+0x1C | R/W | Internal Voltage Source Control Register           | 0x0000_0000     |
| <b>SYS_PORCTL</b>           | SYS_BA+0x24 | R/W | Power-On-Reset Controller Register                 | 0x0000_00XX     |
| <b>SYS_VREFCTL</b>          | SYS_BA+0x28 | R/W | V <sub>REF</sub> Control Register                  | 0x0000_0200     |
| <b>SYS_USBPHY</b>           | SYS_BA+0x2C | R/W | USB PHY Control Register                           | 0x0003_0007     |
| <b>SYS_GPA_MFPL</b>         | SYS_BA+0x30 | R/W | GPIOA Low Byte Multiple Function Control Register  | 0x0000_0000     |
| <b>SYS_GPA_MFPH</b>         | SYS_BA+0x34 | R/W | GPIOA High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPB_MFPL</b>         | SYS_BA+0x38 | R/W | GPIOB Low Byte Multiple Function Control Register  | 0x0000_0000     |
| <b>SYS_GPB_MFPH</b>         | SYS_BA+0x3C | R/W | GPIOB High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPC_MFPL</b>         | SYS_BA+0x40 | R/W | GPIOC Low Byte Multiple Function Control Register  | 0x0000_0000     |
| <b>SYS_GPC_MFPH</b>         | SYS_BA+0x44 | R/W | GPIOC High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPD_MFPL</b>         | SYS_BA+0x48 | R/W | GPIOD Low Byte Multiple Function Control Register  | 0x0000_0000     |
| <b>SYS_GPD_MFPH</b>         | SYS_BA+0x4C | R/W | GPIOD High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPE_MFPL</b>         | SYS_BA+0x50 | R/W | GPIOE Low Byte Multiple Function Control Register  | 0x0000_0000     |
| <b>SYS_GPE_MFPH</b>         | SYS_BA+0x54 | R/W | GPIOE High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPF_MFPL</b>         | SYS_BA+0x58 | R/W | GPIOF Low Byte Multiple Function Control Register  | 0x0000_00EE     |
| <b>SYS_GPF_MFPH</b>         | SYS_BA+0x5C | R/W | GPIOF High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPG_MFPL</b>         | SYS_BA+0x60 | R/W | GPIOG Low Byte Multiple Function Control Register  | 0x0000_0000     |
| <b>SYS_GPG_MFPH</b>         | SYS_BA+0x64 | R/W | GPIOG High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPH_MFPL</b>         | SYS_BA+0x68 | R/W | GPIOH Low Byte Multiple Function Control Register  | 0x0000_0000     |
| <b>SYS_GPH_MFPH</b>         | SYS_BA+0x6C | R/W | GPIOH High Byte Multiple Function Control Register | 0x0000_0000     |
| <b>SYS_GPA_MFOS</b>         | SYS_BA+0x80 | R/W | GPIOA Multiple Function Output Select Register     | 0x0000_0000     |

|                          |              |     |                                                 |             |
|--------------------------|--------------|-----|-------------------------------------------------|-------------|
| <b>SYS_GPB_MFOS</b>      | SYS_BA+0x84  | R/W | GPIOB Multiple Function Output Select Register  | 0x0000_0000 |
| <b>SYS_GPC_MFOS</b>      | SYS_BA+0x88  | R/W | GPIOC Multiple Function Output Select Register  | 0x0000_0000 |
| <b>SYS_GPD_MFOS</b>      | SYS_BA+0x8C  | R/W | GPIOD Multiple Function Output Select Register  | 0x0000_0000 |
| <b>SYS_GPE_MFOS</b>      | SYS_BA+0x90  | R/W | GPIOE Multiple Function Output Select Register  | 0x0000_0000 |
| <b>SYS_GPF_MFOS</b>      | SYS_BA+0x94  | R/W | GPIOF Multiple Function Output Select Register  | 0x0000_0000 |
| <b>SYS_GPG_MFOS</b>      | SYS_BA+0x98  | R/W | GPIOG Multiple Function Output Select Register  | 0x0000_0000 |
| <b>SYS_GPH_MFOS</b>      | SYS_BA+0x9C  | R/W | GPIOH Multiple Function Output Select Register  | 0x0000_0000 |
| <b>SYS_SRAM_INTC_TL</b>  | SYS_BA+0xC0  | R/W | System SRAM Interrupt Enable Control Register   | 0x0000_0000 |
| <b>SYS_SRAM_STAT_US</b>  | SYS_BA+0xC4  | R/W | System SRAM Parity Error Status Register        | 0x0000_0000 |
| <b>SYS_SRAM_ERR_ADDR</b> | SYS_BA+0xC8  | R   | System SRAM Parity Check Error Address Register | 0x0000_0000 |
| <b>SYS_SRAM_BIST_CTL</b> | SYS_BA+0xD0  | R/W | System SRAM BIST Test Control Register          | 0x0000_0000 |
| <b>SYS_SRAM_BIST_STS</b> | SYS_BA+0xD4  | R   | System SRAM BIST Test Status Register           | 0x00xx_00xx |
| <b>SYS_IRCTCTL</b>       | SYS_BA+0xF0  | R/W | HIRC Trim Control Register                      | 0x0000_0000 |
| <b>SYS_IRCTIEN</b>       | SYS_BA+0xF4  | R/W | HIRC Trim Interrupt Enable Register             | 0x0000_0000 |
| <b>SYS_IRCTISTS</b>      | SYS_BA+0xF8  | R/W | HIRC Trim Interrupt Status Register             | 0x0000_0000 |
| <b>SYS_REGLCTL</b>       | SYS_BA+0x100 | R/W | Register Lock Control Register                  | 0x0000_0000 |
| <b>SYS_PLCTL</b>         | SYS_BA+0x1F8 | R/W | Power Level Control Register                    | 0x0000_0000 |
| <b>SYS_PLSTS</b>         | SYS_BA+0x1FC | R/W | Power Level Status Register                     | 0x0000_010X |
| <b>SYS_AHBMCTL</b>       | SYS_BA+0x400 | R/W | AHB Bus Matrix Priority Control Register        | 0x0000_0001 |

### 6.2.12 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 |  |  |  | 0x0045_1A93 <sup>[1]</sup> |

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



| Bits   | Description |                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | PDID        | <b>Part Device Identification Number (Read Only)</b><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+0x04 | R/W | System Reset Status Register |  |  |  | 0x0000_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 |          |       |       |      |       |       | CPULKRF |
| 7        | 6        | 5     | 4     | 3    | 2     | 1     | 0       |
| CPURF    | Reserved | SYSRF | BODRF | LVRF | WDTRF | PINRF | PORF    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [8]    | CPULKRF     | <b>CPU Lockup Reset Flag</b><br>0 = No reset from CPU lockup happened.<br>1 = The Cortex®-M4 lockup happened and chip is reset.<br><b>Note1:</b> Write 1 to clear this bit to 0.<br><b>Note2:</b> When CPU lockup happened under ICE is connected, This flag will set to 1 but chip will not reset.                                                                                                                                                                         |
| [7]    | CPURF       | <b>CPU Reset Flag</b><br>The CPU reset flag is set by hardware if software writes CPURST (SYS_IPRST0[1]) 1 to reset Cortex®-M4 Core and Flash Memory Controller (FMC).<br>0 = No reset from CPU.<br>1 = The Cortex®-M4 Core and FMC are reset by software setting CPURST to 1.<br><b>Note:</b> Write 1 to clean this bit to 0.                                                                                                                                              |
| [6]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [5]    | SYSRF       | <b>System Reset Flag</b><br>The system reset flag is set by the "Reset Signal" from the Cortex®-M4 Core to indicate the previous reset source.<br>0 = No reset from Cortex®-M4.<br>1 = The Cortex®-M4 had issued the reset signal to reset the system by writing 1 to the bit SYSRESETREQ(AIRCR[2], Application Interrupt and Reset Control Register, address = 0xE000ED0C) in system control registers of Cortex®-M4 core.<br><b>Note:</b> Write 1 to clear this bit to 0. |

| Bits | Description  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4]  | <b>BODRF</b> | <p><b>BOD Reset Flag</b></p> <p>The BOD reset flag is set by the “Reset Signal” from the Brown-Out Detector to indicate the previous reset source.</p> <p>0 = No reset from BOD.</p> <p>1 = The BOD had issued the reset signal to reset the system.</p> <p><b>Note:</b> Write 1 to clear this bit to 0.</p>                                                                                                                                                                                                                                                                                                                                                  |
| [3]  | <b>LVRF</b>  | <p><b>LVR Reset Flag</b></p> <p>The LVR reset flag is set by the “Reset Signal” from the Low Voltage Reset Controller to indicate the previous reset source.</p> <p>0 = No reset from LVR.</p> <p>1 = LVR controller had issued the reset signal to reset the system.</p> <p><b>Note:</b> Write 1 to clear this bit to 0.</p>                                                                                                                                                                                                                                                                                                                                 |
| [2]  | <b>WDTRF</b> | <p><b>WDT Reset Flag</b></p> <p>The WDT reset flag is set by the “Reset Signal” from the Watchdog Timer or Window Watchdog Timer to indicate the previous reset source.</p> <p>0 = No reset from watchdog timer or window watchdog timer.</p> <p>1 = The watchdog timer or window watchdog timer had issued the reset signal to reset the system.</p> <p><b>Note1:</b> Write 1 to clear this bit to 0.</p> <p><b>Note2:</b> Watchdog Timer register RSTF(WDT_CTL[2]) bit is set if the system has been reset by WDT time-out reset. Window Watchdog Timer register WWDTRF(WWDT_STATUS[1]) bit is set if the system has been reset by WWDT time-out reset.</p> |
| [1]  | <b>PINRF</b> | <p><b>NRESET Pin Reset Flag</b></p> <p>The nRESET pin reset flag is set by the “Reset Signal” from the nRESET Pin to indicate the previous reset source.</p> <p>0 = No reset from nRESET pin.</p> <p>1 = Pin nRESET had issued the reset signal to reset the system.</p> <p><b>Note:</b> Write 1 to clear this bit to 0.</p>                                                                                                                                                                                                                                                                                                                                  |
| [0]  | <b>PORF</b>  | <p><b>POR Reset Flag</b></p> <p>The POR reset flag is set by the “Reset Signal” from the Power-on Reset (POR) Controller or bit CHIPRST (SYS_IPRST0[0]) to indicate the previous reset source.</p> <p>0 = No reset from POR or CHIPRST.</p> <p>1 = Power-on Reset (POR) or CHIPRST had issued the reset signal to reset the system.</p> <p><b>Note:</b> Write 1 to clear this bit to 0.</p>                                                                                                                                                                                                                                                                   |

Peripheral Reset Control Register 0 (SYS\_IPRST0)

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

|          |         |          |          |          |           |          |           |
|----------|---------|----------|----------|----------|-----------|----------|-----------|
| 31       | 30      | 29       | 28       | 27       | 26        | 25       | 24        |
| ETMCRST  | SWDCRST | Reserved |          |          |           |          |           |
| 23       | 22      | 21       | 20       | 19       | 18        | 17       | 16        |
| Reserved |         |          |          |          |           | SDH1RST  | HSUSBHRST |
| 15       | 14      | 13       | 12       | 11       | 10        | 9        | 8         |
| Reserved | SPIMRST | Reserved | CRPTRST  | Reserved | HSUSBDRST | Reserved |           |
| 7        | 6       | 5        | 4        | 3        | 2         | 1        | 0         |
| CRCRST   | SDH0RST | EMACRST  | Reserved | EBIRST   | PDMARST   | CPURST   | CHIPRST   |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | ETMCRST     | <b>ETM Controller Reset</b><br>Setting this bit to 1 will generate a reset signal to the ETM controller. User needs to set this bit to 0 to release from the reset state.<br>0 = ETM controller normal operation.<br>1 = ETM controller reset.                                                                                                                 |
| [30]    | SWDCRST     | <b>SWD Controller Reset</b><br>Setting this bit to 1 will generate a reset signal to the SWD controller. User needs to set this bit to 0 to release from the reset state.<br>0 = SWD controller normal operation.<br>1 = SWD controller reset.                                                                                                                 |
| [29:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [17]    | SDH1RST     | <b>SDHOST1 Controller Reset (Write Protect)</b><br>Setting this bit to 1 will generate a reset signal to the SDHOST1 controller. User needs to set this bit to 0 to release from the reset state.<br>0 = SDHOST1 controller normal operation.<br>1 = SDHOST1 controller reset.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [16]    | HSUSBHRST   | <b>HSUSBH Controller Reset (Write Protect)</b><br>Set this bit to 1 will generate a reset signal to the HSUSBH controller. User needs to set this bit to 0 to release from the reset state.<br>0 = HSUSBH controller normal operation.<br>1 = HSUSBH controller reset.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.         |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [14]    | SPIMRST     | <b>SPIM Controller Reset</b><br>Setting this bit to 1 will generate a reset signal to the SPIM controller. User needs to set this bit to 0 to release from the reset state.<br>0 = SPIM controller normal operation.                                                                                                                                           |

|       |                  |                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                  | 1 = SPIM controller reset.                                                                                                                                                                                                                                                                                                                                                                                     |
| [13]  | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [12]  | <b>CRPTRST</b>   | <p><b>CRYPTO Controller Reset (Write Protect)</b></p> <p>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.</p> <p>0 = CRYPTO controller normal operation.<br/>1 = CRYPTO controller reset.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                 |
| [11]  | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [10]  | <b>HSUSBDRST</b> | <p><b>HSUSBD Controller Reset (Write Protect)</b></p> <p>Setting this bit to 1 will generate a reset signal to the HSUSBD controller. User needs to set this bit to 0 to release from the reset state.</p> <p>0 = HSUSBD controller normal operation.<br/>1 = HSUSBD controller reset.</p>                                                                                                                     |
| [9:8] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [7]   | <b>CRCRST</b>    | <p><b>CRC Calculation Controller Reset (Write Protect)</b></p> <p>Set this bit to 1 will generate a reset signal to the CRC calculation controller. User needs to set this bit to 0 to release from the reset state.</p> <p>0 = CRC calculation controller normal operation.<br/>1 = CRC calculation controller reset.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [6]   | <b>SDH0RST</b>   | <p><b>SDHOST0 Controller Reset (Write Protect)</b></p> <p>Setting this bit to 1 will generate a reset signal to the SDHOST0 controller. User needs to set this bit to 0 to release from the reset state.</p> <p>0 = SDHOST0 controller normal operation.<br/>1 = SDHOST0 controller reset.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                             |
| [5]   | <b>EMACRST</b>   | <p><b>EMAC Controller Reset (Write Protect)</b></p> <p>Setting this bit to 1 will generate a reset signal to the EMAC controller. User needs to set this bit to 0 to release from the reset state.</p> <p>0 = EMAC controller normal operation.<br/>1 = EMAC controller reset.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                         |
| [4]   | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3]   | <b>EBIRST</b>    | <p><b>EBI Controller Reset (Write Protect)</b></p> <p>Set this bit to 1 will generate a reset signal to the EBI. User needs to set this bit to 0 to release from the reset state.</p> <p>0 = EBI controller normal operation.<br/>1 = EBI controller reset.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                            |
| [2]   | <b>PDMARST</b>   | <p><b>PDMA Controller Reset (Write Protect)</b></p> <p>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.</p> <p>0 = PDMA controller normal operation.<br/>1 = PDMA controller reset.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register</p>                                                         |
| [1]   | <b>CPURST</b>    | <b>Processor Core One-shot Reset (Write Protect)</b>                                                                                                                                                                                                                                                                                                                                                           |

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

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

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

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

| 31        | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
|-----------|----------|----------|----------|----------|----------|----------|----------|
| Reserved  | HSOTGRST | I2S0RST  | EADCRST  | USBDRST  | OTGRST   | CAN1RST  | CAN0RST  |
| 23        | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| Reserved  |          | UART5RST | UART4RST | UART3RST | UART2RST | UART1RST | UART0RST |
| 15        | 14       | 13       | 12       | 11       | 10       | 9        | 8        |
| SPI2RST   | SPI1RST  | SPI0RST  | QSPI0RST | Reserved | I2C2RST  | I2C1RST  | I2C0RST  |
| 7         | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| ACMP01RST | Reserved | TMR3RST  | TMR2RST  | TMR1RST  | TMR0RST  | GPIORST  | Reserved |

| Bits    | Description |                                                                                                        |
|---------|-------------|--------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                              |
| [30]    | HSOTGRST    | <b>HSOTG Controller Reset</b><br>0 = HSOTG controller normal operation.<br>1 = HSOTG controller reset. |
| [29]    | I2S0RST     | <b>I2S0 Controller Reset</b><br>0 = I2S0 controller normal operation.<br>1 = I2S0 controller reset.    |
| [28]    | EADCRST     | <b>EADC Controller Reset</b><br>0 = EADC controller normal operation.<br>1 = EADC controller reset.    |
| [27]    | USBDRST     | <b>USBD Controller Reset</b><br>0 = USBD controller normal operation.<br>1 = USBD controller reset.    |
| [26]    | OTGRST      | <b>OTG Controller Reset</b><br>0 = OTG controller normal operation.<br>1 = OTG controller reset.       |
| [25]    | CAN1RST     | <b>CAN1 Controller Reset</b><br>0 = CAN1 controller normal operation.<br>1 = CAN1 controller reset.    |
| [24]    | CAN0RST     | <b>CAN0 Controller Reset</b><br>0 = CAN0 controller normal operation.<br>1 = CAN0 controller reset.    |
| [23:22] | Reserved    | Reserved.                                                                                              |

|      |                  |                                                                                                                                                        |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [21] | <b>UART5RST</b>  | <b>UART5 Controller Reset</b><br>0 = UART5 controller normal operation.<br>1 = UART5 controller reset.                                                 |
| [20] | <b>UART4RST</b>  | <b>UART4 Controller Reset</b><br>0 = UART4 controller normal operation.<br>1 = UART4 controller reset.                                                 |
| [19] | <b>UART3RST</b>  | <b>UART3 Controller Reset</b><br>0 = UART3 controller normal operation.<br>1 = UART3 controller reset.                                                 |
| [18] | <b>UART2RST</b>  | <b>UART2 Controller Reset</b><br>0 = UART2 controller normal operation.<br>1 = UART2 controller reset.                                                 |
| [17] | <b>UART1RST</b>  | <b>UART1 Controller Reset</b><br>0 = UART1 controller normal operation.<br>1 = UART1 controller reset.                                                 |
| [16] | <b>UART0RST</b>  | <b>UART0 Controller Reset</b><br>0 = UART0 controller normal operation.<br>1 = UART0 controller reset.                                                 |
| [15] | <b>SPI2RST</b>   | <b>SPI2 Controller Reset</b><br>0 = SPI2 controller normal operation.<br>1 = SPI2 controller reset.                                                    |
| [14] | <b>SPI1RST</b>   | <b>SPI1 Controller Reset</b><br>0 = SPI1 controller normal operation.<br>1 = SPI1 controller reset.                                                    |
| [13] | <b>SPI0RST</b>   | <b>SPI0 Controller Reset</b><br>0 = SPI0 controller normal operation.<br>1 = SPI0 controller reset.                                                    |
| [12] | <b>QSPI0RST</b>  | <b>QSPI0 Controller Reset</b><br>0 = QSPI0 controller normal operation.<br>1 = QSPI0 controller reset.                                                 |
| [11] | <b>Reserved</b>  | Reserved.                                                                                                                                              |
| [10] | <b>I2C2RST</b>   | <b>I2C2 Controller Reset</b><br>0 = I2C2 controller normal operation.<br>1 = I2C2 controller reset.                                                    |
| [9]  | <b>I2C1RST</b>   | <b>I2C1 Controller Reset</b><br>0 = I2C1 controller normal operation.<br>1 = I2C1 controller reset.                                                    |
| [8]  | <b>I2C0RST</b>   | <b>I2C0 Controller Reset</b><br>0 = I2C0 controller normal operation.<br>1 = I2C0 controller reset.                                                    |
| [7]  | <b>ACMP01RST</b> | <b>Analog Comparator 0/1 Controller Reset</b><br>0 = Analog Comparator 0/1 controller normal operation.<br>1 = Analog Comparator 0/1 controller reset. |

|     |                 |                                                                                                           |
|-----|-----------------|-----------------------------------------------------------------------------------------------------------|
| [6] | <b>Reserved</b> | Reserved.                                                                                                 |
| [5] | <b>TMR3RST</b>  | <b>Timer3 Controller Reset</b><br>0 = Timer3 controller normal operation.<br>1 = Timer3 controller reset. |
| [4] | <b>TMR2RST</b>  | <b>Timer2 Controller Reset</b><br>0 = Timer2 controller normal operation.<br>1 = Timer2 controller reset. |
| [3] | <b>TMR1RST</b>  | <b>Timer1 Controller Reset</b><br>0 = Timer1 controller normal operation.<br>1 = Timer1 controller reset. |
| [2] | <b>TMR0RST</b>  | <b>Timer0 Controller Reset</b><br>0 = Timer0 controller normal operation.<br>1 = Timer0 controller reset. |
| [1] | <b>GPIORST</b>  | <b>GPIO Controller Reset</b><br>0 = GPIO controller normal operation.<br>1 = GPIO controller reset.       |
| [0] | <b>Reserved</b> | Reserved.                                                                                                 |

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

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

| Register   | Offset      | R/W | Description                         |  |  |  | Reset Value |
|------------|-------------|-----|-------------------------------------|--|--|--|-------------|
| SYS_IPRST2 | SYS_BA+0x10 | R/W | Peripheral Reset Control Register 2 |  |  |  | 0x0000_0000 |

| 31       | 30      | 29       | 28 | 27       | 26       | 25       | 24       |
|----------|---------|----------|----|----------|----------|----------|----------|
| Reserved | OPARST  | Reserved |    | ECAP1RST | ECAP0RST | Reserved |          |
| 23       | 22      | 21       | 20 | 19       | 18       | 17       | 16       |
| QEI1RST  | QEI0RST | Reserved |    | BPWM1RST | BPWM0RST | EPWM1RST | EPWM0RST |
| 15       | 14      | 13       | 12 | 11       | 10       | 9        | 8        |
| Reserved |         | DACRST   |    | Reserved |          | USCI1RST | USCI0RST |
| 7        | 6       | 5        | 4  | 3        | 2        | 1        | 0        |
| Reserved | SPI3RST | Reserved |    |          | SC2RST   | SC1RST   | SC0RST   |

| Bits    | Description |                                                                                                                 |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                       |
| [30]    | OPARST      | <b>OP Amplifier (OPA) Controller Reset</b><br>0 = OPA controller normal operation.<br>1 = OPA controller reset. |
| [29:28] | Reserved    | Reserved.                                                                                                       |
| [27]    | ECAP1RST    | <b>ECAP1 Controller Reset</b><br>0 = ECAP1 controller normal operation.<br>1 = ECAP1 controller reset.          |
| [26]    | ECAP0RST    | <b>ECAP0 Controller Reset</b><br>0 = ECAP0 controller normal operation.<br>1 = ECAP0 controller reset.          |
| [25:24] | Reserved    | Reserved.                                                                                                       |
| [23]    | QEI1RST     | <b>QEI1 Controller Reset</b><br>0 = QEI1 controller normal operation.<br>1 = QEI1 controller reset.             |
| [22]    | QEI0RST     | <b>QEI0 Controller Reset</b><br>0 = QEI0 controller normal operation.<br>1 = QEI0 controller reset.             |
| [21:20] | Reserved    | Reserved.                                                                                                       |
| [19]    | BPWM1RST    | <b>BPWM1 Controller Reset</b><br>0 = BPWM1 controller normal operation.<br>1 = BPWM1 controller reset.          |

|         |                 |                                                                                                        |
|---------|-----------------|--------------------------------------------------------------------------------------------------------|
| [18]    | <b>BPWM0RST</b> | <b>BPWM0 Controller Reset</b><br>0 = BPWM0 controller normal operation.<br>1 = BPWM0 controller reset. |
| [17]    | <b>EPWM1RST</b> | <b>EPWM1 Controller Reset</b><br>0 = EPWM1 controller normal operation.<br>1 = EPWM1 controller reset. |
| [16]    | <b>EPWM0RST</b> | <b>EPWM0 Controller Reset</b><br>0 = EPWM0 controller normal operation.<br>1 = EPWM0 controller reset. |
| [15:13] | <b>Reserved</b> | Reserved.                                                                                              |
| [12]    | <b>DACRST</b>   | <b>DAC Controller Reset</b><br>0 = DAC controller normal operation.<br>1 = DAC controller reset.       |
| [11:10] | <b>Reserved</b> | Reserved.                                                                                              |
| [9]     | <b>USCI1RST</b> | <b>USCI1 Controller Reset</b><br>0 = USCI1 controller normal operation.<br>1 = USCI1 controller reset. |
| [8]     | <b>USCI0RST</b> | <b>USCI0 Controller Reset</b><br>0 = USCI0 controller normal operation.<br>1 = USCI0 controller reset. |
| [7]     | <b>Reserved</b> | Reserved.                                                                                              |
| [6]     | <b>SPI3RST</b>  | <b>SPI3 Controller Reset</b><br>0 = SPI3 controller normal operation.<br>1 = SPI3 controller reset.    |
| [5:3]   | <b>Reserved</b> | Reserved.                                                                                              |
| [2]     | <b>SC2RST</b>   | <b>SC2 Controller Reset</b><br>0 = SC2 controller normal operation.<br>1 = SC2 controller reset.       |
| [1]     | <b>SC1RST</b>   | <b>SC1 Controller Reset</b><br>0 = SC1 controller normal operation.<br>1 = SC1 controller reset.       |
| [0]     | <b>SC0RST</b>   | <b>SC0 Controller Reset</b><br>0 = SC0 controller normal operation.<br>1 = SC0 controller reset.       |

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

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

| Register   | Offset      | R/W | Description                         |  |  |  | Reset Value |
|------------|-------------|-----|-------------------------------------|--|--|--|-------------|
| SYS_BODCTL | SYS_BA+0x18 | R/W | Brown-Out Detector Control Register |  |  |  | 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 | Reserved |    | BODEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [18:16] | BODVL       | <p><b>Brown-out Detector Threshold Voltage Selection (Write Protect)</b><br/>           The default value is set by flash controller user configuration register CBOV (CONFIG0 [23:21]).</p> <p>000 = Brown-Out Detector threshold voltage is 1.6V.<br/>           001 = Brown-Out Detector threshold voltage is 1.8V.<br/>           010 = Brown-Out Detector threshold voltage is 2.0V.<br/>           011 = Brown-Out Detector threshold voltage is 2.2V.<br/>           100 = Brown-Out Detector threshold voltage is 2.4V.<br/>           101 = Brown-Out Detector threshold voltage is 2.6V.<br/>           110 = Brown-Out Detector threshold voltage is 2.8V.<br/>           111 = Brown-Out Detector threshold voltage is 3.0V.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [14:12] | LVRDGSEL    | <p><b>LVR Output De-glitch Time Select (Write Protect)</b><br/>           000 = Without de-glitch function.<br/>           001 = 4 system clock (HCLK).<br/>           010 = 8 system clock (HCLK).<br/>           011 = 16 system clock (HCLK).<br/>           100 = 32 system clock (HCLK).<br/>           101 = 64 system clock (HCLK).<br/>           110 = 128 system clock (HCLK).<br/>           111 = 256 system clock (HCLK).</p> <p><b>Note:</b> These bits are write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10:8] | <p><b>BODDGSEL</b></p> <p><b>Brown-out Detector Output De-glitch Time Select (Write Protect)</b></p> <p>000 = BOD output is sampled by RC10K clock.<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).</p> <p><b>Note:</b> These bits are write protected. Refer to the SYS_REGLCTL register.</p>                                   |
| [7]    | <p><b>LVREN</b></p> <p><b>Low Voltage Reset Enable Bit (Write Protect)</b></p> <p>The LVR function resets the chip when the input power voltage is lower than LVR circuit setting. LVR function is enabled by default.</p> <p>0 = Low Voltage Reset function Disabled.<br/>     1 = Low Voltage Reset function Enabled.</p> <p><b>Note1:</b> After enabling the bit, the LVR function will be active with 100us delay for LVR output stable (default).</p> <p><b>Note2:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                   |
| [6]    | <p><b>BODOUT</b></p> <p><b>Brown-out Detector Output Status</b></p> <p>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, BOD function disabled , this bit always responds 0000.</p>                                                                                                                                                        |
| [5]    | <p><b>BODLPM</b></p> <p><b>Brown-out Detector Low Power Mode (Write Protect)</b></p> <p>0 = BOD operate in normal mode (default).<br/>     1 = BOD Low Power mode Enabled.</p> <p><b>Note1:</b> The BOD consumes about 100uA in normal mode, the low power mode can reduce the current to about 1/10 but slow the BOD response.</p> <p><b>Note2:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                          |
| [4]    | <p><b>BODIF</b></p> <p><b>Brown-out Detector Interrupt Flag</b></p> <p>0 = Brown-out Detector does not detect any voltage draft at V<sub>DD</sub> down through or up through the voltage of BODVL setting.<br/>     1 = When Brown-out Detector detects the V<sub>DD</sub> is dropped down through the voltage of BODVL setting or the V<sub>DD</sub> 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.</p> <p><b>Note:</b> Write 1 to clear this bit to 0.</p> |

| Bits  | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]   | <b>BODRSTEN</b> | <p><b>Brown-out Reset Enable Bit (Write Protect)</b></p> <p>The default value is set by flash controller user configuration register CBORST(CONFIG0[20]) bit .</p> <p>0 = Brown-out “INTERRUPT” function Enabled.<br/>1 = Brown-out “RESET” function Enabled.</p> <p><b>Note1:</b></p> <p>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).</p> <p>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).</p> <p><b>Note2:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [2:1] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [0]   | <b>BODEN</b>    | <p><b>Brown-out Detector Enable Bit (Write Protect)</b></p> <p>The default value is set by flash controller user configuration register CBODEN (CONFIG0 [19]).</p> <p>0 = Brown-out Detector function Disabled.<br/>1 = Brown-out Detector function Enabled.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> <p><b>Note:</b> When VDD lower than BOD detect voltage level, chip will not run into BOD interrupt vector and cannot enter power-down mode if BOD enabled (SYS_BODCTL[0]) set to 1 but correlated NVIC interrupt enable bit (NVIC_ISER0[0]) set to 0.</p>                                                                                                                                                                                                                                                                                                                              |

Internal Voltage Source Control Register (SYS\_IVSCTL)

| Register   | Offset      | R/W | Description                              |  |  |  |  | Reset Value |
|------------|-------------|-----|------------------------------------------|--|--|--|--|-------------|
| SYS_IVSCTL | SYS_BA+0x1C | R/W | Internal Voltage Source Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [7:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [1]    | VBATUGEN    | <p><b>V<sub>DD</sub> Unity Gain Buffer Enable Bit</b><br/>           This bit is used to enable/disable V<sub>DD</sub> unity gain buffer function.<br/>           0 = V<sub>DD</sub> unity gain buffer function Disabled (default).<br/>           1 = V<sub>DD</sub> unity gain buffer function Enabled.</p> <p><b>Note:</b> After this bit is set to 1, the value of V<sub>DD</sub> unity gain buffer output voltage can be obtained from ADC conversion result</p> |
| [0]    | VTEMPEN     | <p><b>Temperature Sensor Enable Bit</b><br/>           This bit is used to enable/disable temperature sensor function.<br/>           0 = Temperature sensor function Disabled (default).<br/>           1 = Temperature sensor function Enabled.</p> <p><b>Note:</b> After this bit is set to 1, the value of temperature sensor output can be obtained through GPC.9.</p>                                                                                           |

Power-on Reset Controller Register (SYS PORCTL)

| Register   | Offset      | R/W | Description                        |  |  |  | Reset Value |
|------------|-------------|-----|------------------------------------|--|--|--|-------------|
| SYS_PORCTL | SYS_BA+0x24 | R/W | Power-On-Reset Controller Register |  |  |  | 0x0000_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  |
| POROFF   |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| POROFF   |    |    |    |    |    |    |    |

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

VREF Control Register (SYS\_VREFCTL)

| Register    | Offset      | R/W | Description           |  |  |  |  | Reset Value |
|-------------|-------------|-----|-----------------------|--|--|--|--|-------------|
| SYS_VREFCTL | SYS_BA+0x28 | R/W | VREF Control Register |  |  |  |  | 0x0000_0200 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                           |
| [7:6]  | PRELOAD_SEL | <b>Pre-load Timing Selection (Write Protect)</b><br>00 = pre-load time is 60us for 0.1uF Capacitor.<br>01 = pre-load time is 310us for 1uF Capacitor.<br>10 = pre-load time is 1270us for 4.7uF Capacitor.<br>11 = pre-load time is 2650us for 10uF Capacitor.                                                                                                                                      |
| [5]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                           |
| [4:0]  | VREFCTL     | <b>V<sub>REF</sub> Control Bits (Write Protect)</b><br>00000 = V <sub>REF</sub> is from external pin.<br>00011 = V <sub>REF</sub> is internal 1.6V.<br>00111 = V <sub>REF</sub> is internal 2.0V.<br>01011 = V <sub>REF</sub> is internal 2.5V.<br>01111 = V <sub>REF</sub> is internal 3.0V.<br>Others = Reserved.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |

USB PHY Control Register (SYS\_USBPHY)

| Register   | Offset      | R/W | Description              |  |  |  | Reset Value |
|------------|-------------|-----|--------------------------|--|--|--|-------------|
| SYS_USBPHY | SYS_BA+0x2C | R/W | USB PHY Control Register |  |  |  | 0x0003_0007 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |
| [25]    | HSUSBACT    | <p><b>HSUSB PHY Active Control</b><br/>           This bit is used to control HSUSB PHY at reset state or active state<br/>           0 = HSUSB PHY at reset state.<br/>           1 = HSUSB PHY at active state.<br/> <b>Note:</b> After set HSUSBEN (SYS_USBPHY[24]) to enable HSUSB PHY, user should keep HSUSB PHY at reset mode at lease 10uS before changing to active mode</p> |
| [24]    | HSUSBEN     | <p><b>HSUSB PHY Enable</b><br/>           This bit is used to enable/disable HSUSB PHY.<br/>           0 = HSUSB PHY Disabled.<br/>           1 = HSUSB PHY Enabled.</p>                                                                                                                                                                                                              |
| [23:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |
| [17:16] | HSUSBROLE   | <p><b>HSUSB Role Option (Write Protect)</b><br/>           These two bits are used to select the role of HSUSB<br/>           00 = Standard HSUSB Device mode.<br/>           01 = Standard HSUSB Host mode.<br/>           10 = ID dependent mode.<br/>           11 = Reserved.<br/> <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>               |
| [15:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |
| [8]     | USBEN       | <p><b>USB PHY Enable</b><br/>           This bit is used to enable/disable USB PHY.<br/>           0 = USB PHY Disabled.<br/>           1 = USB PHY Enabled.</p>                                                                                                                                                                                                                      |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |
| [2]     | SBO         | <b>Note:</b> This bit must always be kept 1. If set to 0, the result is unpredictable                                                                                                                                                                                                                                                                                                 |

|       |                |                                                                                                                                                                                                                                                                                             |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0] | <b>USBROLE</b> | <b>USB Role Option (Write Protect)</b><br>These two bits are used to select the role of USB.<br>00 = Standard USB Device mode.<br>01 = Standard USB Host mode.<br>10 = ID dependent mode.<br>11 = Reserved.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

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

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

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

| 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]   | PA1MFP      | PA.1 Multi-function Pin Selection |
| [3:0]   | PA0MFP      | PA.0 Multi-function Pin Selection |

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

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

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

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

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

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

|        |    |    |    |        |    |    |    |
|--------|----|----|----|--------|----|----|----|
| 31     | 30 | 29 | 28 | 27     | 26 | 25 | 24 |
| PB7MFP |    |    |    | PB6MFP |    |    |    |
| 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
| PB5MFP |    |    |    | PB4MFP |    |    |    |
| 15     | 14 | 13 | 12 | 11     | 10 | 9  | 8  |
| 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]   | PB1MFP      | PB.1 Multi-function Pin Selection |
| [3:0]   | PB0MFP      | PB.0 Multi-function Pin Selection |

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

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

|         |    |    |    |         |    |    |    |
|---------|----|----|----|---------|----|----|----|
| 31      | 30 | 29 | 28 | 27      | 26 | 25 | 24 |
| 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]   | PB9MFP      | PB.9 Multi-function Pin Selection  |
| [3:0]   | PB8MFP      | PB.8 Multi-function Pin Selection  |

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

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

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

| 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]  | PC2MFP      | PC.2 Multi-function Pin Selection |
| [7:4]   | PC1MFP      | PC.1 Multi-function Pin Selection |
| [3:0]   | PC0MFP      | PC.0 Multi-function Pin Selection |

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

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

|         |    |    |    |         |    |    |    |
|---------|----|----|----|---------|----|----|----|
| 31      | 30 | 29 | 28 | 27      | 26 | 25 | 24 |
| 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]   | PC8MFP      | 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 |  |  |  | 0x0000_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 |    |    |    | PD0MFP |    |    |    |

| 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]  | PD2MFP      | PD.2 Multi-function Pin Selection |
| [7:4]   | PD1MFP      | PD.1 Multi-function Pin Selection |
| [3:0]   | PD0MFP      | PD.0 Multi-function Pin Selection |

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

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

|         |    |    |    |         |    |    |    |
|---------|----|----|----|---------|----|----|----|
| 31      | 30 | 29 | 28 | 27      | 26 | 25 | 24 |
| 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]   | PD9MFP      | PD.9 Multi-function Pin Selection  |
| [3:0]   | PD8MFP      | PD.8 Multi-function Pin Selection  |

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

| Register     | Offset      | R/W | Description                                       |  |  |  | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|--|--|--|-------------|
| SYS_GPE_MFPL | SYS_BA+0x50 | R/W | GPIOE Low Byte Multiple Function Control Register |  |  |  | 0x0000_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]   | PE1MFP      | PE.1 Multi-function Pin Selection |
| [3:0]   | PE0MFP      | PE.0 Multi-function Pin Selection |

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

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

|         |    |    |    |         |    |    |    |
|---------|----|----|----|---------|----|----|----|
| 31      | 30 | 29 | 28 | 27      | 26 | 25 | 24 |
| PE15MFP |    |    |    | PE14MFP |    |    |    |
| 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 |                                    |
|---------|-------------|------------------------------------|
| [31:28] | PE15MFP     | PE.15 Multi-function Pin Selection |
| [27:24] | PE14MFP     | PE.14 Multi-function Pin Selection |
| [23:20] | PE13MFP     | PE.13 Multi-function Pin Selection |
| [19:16] | PE12MFP     | PE.12 Multi-function Pin Selection |
| [15:12] | PE11MFP     | PE.11 Multi-function Pin Selection |
| [11:8]  | PE10MFP     | PE.10 Multi-function Pin Selection |
| [7:4]   | PE9MFP      | PE.9 Multi-function Pin Selection  |
| [3:0]   | PE8MFP      | PE.8 Multi-function Pin Selection  |

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

| Register     | Offset      | R/W | Description                                       |  |  |  | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|--|--|--|-------------|
| SYS_GPF_MFPL | SYS_BA+0x58 | R/W | GPIOF Low Byte Multiple Function Control Register |  |  |  | 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 |    |    |    | PF0MFP |    |    |    |

| 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]  | PF2MFP      | PF.2 Multi-function Pin Selection |
| [7:4]   | PF1MFP      | PF.1 Multi-function Pin Selection |
| [3:0]   | PF0MFP      | PF.0 Multi-function Pin Selection |

**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 |  |  |  | 0x0000_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]   | PF9MFP      | PF.9 Multi-function Pin Selection  |
| [3:0]   | PF8MFP      | PF.8 Multi-function Pin Selection  |

**GPIOG Low Byte Multiple Function Control Register (SYS\_GPG\_MFPL)**

| Register     | Offset      | R/W | Description                                       |  |  |  | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|--|--|--|-------------|
| SYS_GPG_MFPL | SYS_BA+0x60 | R/W | GPIOG Low Byte Multiple Function Control Register |  |  |  | 0x0000_0000 |

|        |    |    |    |        |    |    |    |
|--------|----|----|----|--------|----|----|----|
| 31     | 30 | 29 | 28 | 27     | 26 | 25 | 24 |
| PG7MFP |    |    |    | PG6MFP |    |    |    |
| 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
| PG5MFP |    |    |    | PG4MFP |    |    |    |
| 15     | 14 | 13 | 12 | 11     | 10 | 9  | 8  |
| PG3MFP |    |    |    | PG2MFP |    |    |    |
| 7      | 6  | 5  | 4  | 3      | 2  | 1  | 0  |
| PG1MFP |    |    |    | PG0MFP |    |    |    |

| Bits    | Description |                                   |
|---------|-------------|-----------------------------------|
| [31:28] | PG7MFP      | PG.7 Multi-function Pin Selection |
| [27:24] | PG6MFP      | PG.6 Multi-function Pin Selection |
| [23:20] | PG5MFP      | PG.5 Multi-function Pin Selection |
| [19:16] | PG4MFP      | PG.4 Multi-function Pin Selection |
| [15:12] | PG3MFP      | PG.3 Multi-function Pin Selection |
| [11:8]  | PG2MFP      | PG.2 Multi-function Pin Selection |
| [7:4]   | PG1MFP      | PG.1 Multi-function Pin Selection |
| [3:0]   | PG0MFP      | PG.0 Multi-function Pin Selection |

**GPIOG High Byte Multiple Function Control Register (SYS\_GPG\_MFPH)**

| Register      | Offset      | R/W | Description                                        |  |  |  | Reset Value |
|---------------|-------------|-----|----------------------------------------------------|--|--|--|-------------|
| SYS_GPG_MFP_H | SYS_BA+0x64 | R/W | GPIOG High Byte Multiple Function Control Register |  |  |  | 0x0000_0000 |

|         |    |    |    |         |    |    |    |
|---------|----|----|----|---------|----|----|----|
| 31      | 30 | 29 | 28 | 27      | 26 | 25 | 24 |
| PG15MFP |    |    |    | PG14MFP |    |    |    |
| 23      | 22 | 21 | 20 | 19      | 18 | 17 | 16 |
| PG13MFP |    |    |    | PG12MFP |    |    |    |
| 15      | 14 | 13 | 12 | 11      | 10 | 9  | 8  |
| PG11MFP |    |    |    | PG10MFP |    |    |    |
| 7       | 6  | 5  | 4  | 3       | 2  | 1  | 0  |
| PG9MFP  |    |    |    | PG8MFP  |    |    |    |

| Bits    | Description |                                    |
|---------|-------------|------------------------------------|
| [31:28] | PG15MFP     | PG.15 Multi-function Pin Selection |
| [27:24] | PG14MFP     | PG.14 Multi-function Pin Selection |
| [23:20] | PG13MFP     | PG.13 Multi-function Pin Selection |
| [19:16] | PG12MFP     | PG.12 Multi-function Pin Selection |
| [15:12] | PG11MFP     | PG.11 Multi-function Pin Selection |
| [11:8]  | PG10MFP     | PG.10 Multi-function Pin Selection |
| [7:4]   | PG9MFP      | PG.9 Multi-function Pin Selection  |
| [3:0]   | PG8MFP      | PG.8 Multi-function Pin Selection  |

**GPIOH Low Byte Multiple Function Control Register (SYS\_GPH\_MFPL)**

| Register     | Offset      | R/W | Description                                       |  |  |  | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|--|--|--|-------------|
| SYS_GPH_MFPL | SYS_BA+0x68 | R/W | GPIOH Low Byte Multiple Function Control Register |  |  |  | 0x0000_0000 |

|        |    |    |    |        |    |    |    |
|--------|----|----|----|--------|----|----|----|
| 31     | 30 | 29 | 28 | 27     | 26 | 25 | 24 |
| PH7MFP |    |    |    | PH6MFP |    |    |    |
| 23     | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
| PH5MFP |    |    |    | PH4MFP |    |    |    |
| 15     | 14 | 13 | 12 | 11     | 10 | 9  | 8  |
| PH3MFP |    |    |    | PH2MFP |    |    |    |
| 7      | 6  | 5  | 4  | 3      | 2  | 1  | 0  |
| PH1MFP |    |    |    | PH0MFP |    |    |    |

| Bits    | Description |                                   |
|---------|-------------|-----------------------------------|
| [31:28] | PH7MFP      | PH.7 Multi-function Pin Selection |
| [27:24] | PH6MFP      | PH.6 Multi-function Pin Selection |
| [23:20] | PH5MFP      | PH.5 Multi-function Pin Selection |
| [19:16] | PH4MFP      | PH.4 Multi-function Pin Selection |
| [15:12] | PH3MFP      | PH.3 Multi-function Pin Selection |
| [11:8]  | PH2MFP      | PH.2 Multi-function Pin Selection |
| [7:4]   | PH1MFP      | PH.1 Multi-function Pin Selection |
| [3:0]   | PH0MFP      | PH.0 Multi-function Pin Selection |

GPIOH High Byte Multiple Function Control Register (SYS\_GPH\_MFPH)

| Register     | Offset      | R/W | Description                                        |  |  |  | Reset Value |
|--------------|-------------|-----|----------------------------------------------------|--|--|--|-------------|
| SYS_GPH_MFPH | SYS_BA+0x6C | R/W | GPIOH High Byte Multiple Function Control Register |  |  |  | 0x0000_0000 |

|         |    |    |    |         |    |    |    |
|---------|----|----|----|---------|----|----|----|
| 31      | 30 | 29 | 28 | 27      | 26 | 25 | 24 |
| PH15MFP |    |    |    | PH14MFP |    |    |    |
| 23      | 22 | 21 | 20 | 19      | 18 | 17 | 16 |
| PH13MFP |    |    |    | PH12MFP |    |    |    |
| 15      | 14 | 13 | 12 | 11      | 10 | 9  | 8  |
| PH11MFP |    |    |    | PH10MFP |    |    |    |
| 7       | 6  | 5  | 4  | 3       | 2  | 1  | 0  |
| PH9MFP  |    |    |    | PH8MFP  |    |    |    |

| Bits    | Description |                                    |
|---------|-------------|------------------------------------|
| [31:28] | PH15MFP     | PH.15 Multi-function Pin Selection |
| [27:24] | PH14MFP     | PH.14 Multi-function Pin Selection |
| [23:20] | PH13MFP     | PH.13 Multi-function Pin Selection |
| [19:16] | PH12MFP     | PH.12 Multi-function Pin Selection |
| [15:12] | PH11MFP     | PH.11 Multi-function Pin Selection |
| [11:8]  | PH10MFP     | PH.10 Multi-function Pin Selection |
| [7:4]   | PH9MFP      | PH.9 Multi-function Pin Selection  |
| [3:0]   | PH8MFP      | PH.8 Multi-function Pin Selection  |

**GPIO A-H 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 | 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_GPG_MFOS | SYS_BA+0x98 | R/W | GPIOG Multiple Function Output Select Register | 0x0000_0000 |
| SYS_GPH_MFOS | SYS_BA+0x9C | R/W | GPIOH Multiple Function Output Select Register | 0x0000_0000 |

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

| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [n]<br>n=0,1..15 | MFOS        | <p><b>GPIOA-h Pin[n] Multiple Function Pin Output Mode Select</b></p> <p>This bit used to select multiple function pin output mode type for Px.n pin</p> <p>0 = Multiple function pin output mode type is Push-pull mode.</p> <p>1 = Multiple function pin output mode type is Open-drain mode.</p> <p><b>Note:</b></p> <p>Max. n=15 for port A/B/E/G.</p> <p>Max. n=14 for port C/D.</p> <p>Max. n=11 for port F/H.</p> |

**System SRAM Parity Error Interrupt Enable Control Register (SYS\_SRAM\_INTCTL)**

| Register        | Offset      | R/W | Description                                   |  |  |  |  | Reset Value |
|-----------------|-------------|-----|-----------------------------------------------|--|--|--|--|-------------|
| SYS_SRAM_INTCTL | SYS_BA+0xC0 | R/W | System SRAM Interrupt Enable Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                          |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                |
| [0]    | PERRIEN     | <b>SRAM Parity Check Error Interrupt Enable Bit</b><br>0 = SRAM parity check error interrupt Disabled.<br>1 = SRAM parity check error interrupt Enabled. |

**System SRAM Parity Check Status Register (SYS\_SRAM\_STATUS)**

| Register        | Offset      | R/W | Description                              |  |  |  |  | Reset Value |
|-----------------|-------------|-----|------------------------------------------|--|--|--|--|-------------|
| SYS_SRAM_STATUS | SYS_BA+0xC4 | R/W | System SRAM Parity Error 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 |    |    |    |    |    |    | <b>PERRIF</b> |

| Bits   | Description     |                                                                                                                                                                                                                         |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                               |
| [0]    | <b>PERRIF</b>   | <p><b>SRAM Parity Check Error Flag</b></p> <p>This bit indicates the System SRAM parity error occurred. Write 1 to clear this to 0.</p> <p>0 = No System SRAM parity error.<br/>1 = System SRAM parity error occur.</p> |

**System SRAM Parity Error Address Register (SYS\_SRAM\_ERRADDR)**

| Register         | Offset      | R/W | Description                                     |  |  |  | Reset Value |
|------------------|-------------|-----|-------------------------------------------------|--|--|--|-------------|
| SYS_SRAM_ERRADDR | SYS_BA+0xC8 | R   | System SRAM Parity Check Error Address Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                       |
|--------|-------------|-------------------------------------------------------------------------------------------------------|
| [31:0] | ERRADDR     | <b>System SRAM Parity Error Address</b><br>This register shows system SRAM parity error byte address. |

**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 |  |  |  | 0x0000_0000 |

|          |         |          |         |         |        |            |             |
|----------|---------|----------|---------|---------|--------|------------|-------------|
| 31       | 30      | 29       | 28      | 27      | 26     | 25         | 24          |
| Reserved |         |          |         |         |        |            |             |
| 23       | 22      | 21       | 20      | 19      | 18     | 17         | 16          |
| SRB1S5   | SRB1S4  | SRB1S3   | SRB1S2  | SRB1S1  | SRB1S0 | SRB0S1     | SRB0S0      |
| 15       | 14      | 13       | 12      | 11      | 10     | 9          | 8           |
| Reserved |         |          |         |         |        | HSUSBHBIST | HSUSBDDBIST |
| 7        | 6       | 5        | 4       | 3       | 2      | 1          | 0           |
| PDMABIST | EMCBIST | SPIMBIST | USBBIST | CANBIST | CRBIST | SRBIST1    | SRBIST0     |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [23]    | SRB1S5      | <p><b>SRAM Bank1 Section 1 BIST Select (Write Protect)</b></p> <p>This bit define if the sixth 16KB section of SRAM bank1 is selected or not when doing bist test.</p> <p>0 = SRAM bank1 sixth 16KB section is deselected when doing bist test.<br/>1 = SRAM bank1 sixth 16KB section is selected when doing bist test.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> <p><b>Note:</b> At least one section of SRAM bank1 should be selected when doing SRAM bank1 bist test.</p>    |
| [22]    | SRB1S4      | <p><b>SRAM Bank1 Section 0 BIST Select (Write Protect)</b></p> <p>This bit define if the fifth 16KB section of SRAM bank1 is selected or not when doing bist test.</p> <p>0 = SRAM bank1 fifth 16KB section is deselected when doing bist test.<br/>1 = SRAM bank1 fifth 16KB section is selected when doing bist test.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> <p><b>Note:</b> At least one section of SRAM bank1 should be selected when doing SRAM bank1 bist test.</p>    |
| [21]    | SRB1S3      | <p><b>SRAM Bank1 Section 1 BIST Select (Write Protect)</b></p> <p>This bit define if the fourth 16KB section of SRAM bank1 is selected or not when doing bist test.</p> <p>0 = SRAM bank1 fourth 16KB section is deselected when doing bist test.<br/>1 = SRAM bank1 fourth 16KB section is selected when doing bist test.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> <p><b>Note:</b> At least one section of SRAM bank1 should be selected when doing SRAM bank1 bist test.</p> |
| [20]    | SRB1S2      | <p><b>SRAM Bank1 Section 0 BIST Select (Write Protect)</b></p> <p>This bit define if the third 16KB section of SRAM bank1 is selected or not when doing bist test.</p> <p>0 = SRAM bank1 third 16KB section is deselected when doing bist test.</p>                                                                                                                                                                                                                                                                           |

|         |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                    | 1 = SRAM bank1 third 16KB section is selected when doing bist test.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note:</b> At least one section of SRAM bank1 should be selected when doing SRAM bank1 bist test.                                                                                                                                                                                                                                            |
| [19]    | <b>SRB1S1</b>      | <b>SRAM Bank1 Section 1 BIST Select (Write Protect)</b><br>This bit define if the second 16KB section of SRAM bank1 is selected or not when doing bist test.<br>0 = SRAM bank1 second 16KB section is deselected when doing bist test.<br>1 = SRAM bank1 second 16KB section is selected when doing bist test.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note:</b> At least one section of SRAM bank1 should be selected when doing SRAM bank1 bist test. |
| [18]    | <b>SRB1S0</b>      | <b>SRAM Bank1 Section 0 BIST Select (Write Protect)</b><br>This bit define if the first 16KB section of SRAM bank1 is selected or not when doing bist test.<br>0 = SRAM bank1 first 16KB section is deselected when doing bist test.<br>1 = SRAM bank1 first 16KB section is selected when doing bist test.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note:</b> At least one section of SRAM bank1 should be selected when doing SRAM bank1 bist test.    |
| [17]    | <b>SRB0S1</b>      | <b>SRAM Bank0 Section 1 BIST Select (Write Protect)</b><br>This bit define if the second 16KB section of SRAM bank0 is selected or not when doing bist test.<br>0 = SRAM bank0 section 1 is deselected when doing bist test.<br>1 = SRAM bank0 section 1 is selected when doing bist test.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note:</b> At least one section of SRAM bank0 should be selected when doing SRAM bank0 bist test.                     |
| [16]    | <b>SRB0S0</b>      | <b>SRAM Bank0 Section 0 BIST Select (Write Protect)</b><br>This bit define if the first 16KB section of SRAM bank0 is selected or not when doing bist test.<br>0 = SRAM bank0 section 0 is deselected when doing bist test.<br>1 = SRAM bank0 section 0 is selected when doing bist test.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note:</b> At least one section of SRAM bank0 should be selected when doing SRAM bank0 bist test.                      |
| [15:10] | <b>Reserved</b>    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [9]     | <b>HSUSBHBIST</b>  | <b>HSUSBH BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for HSUSBH RAM<br>0 = system HSUSBH BIST Disabled.<br>1 = system HSUSBH BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                     |
| [8]     | <b>HSUSBDDBIST</b> | <b>HSUSBD BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for HSUSBD RAM<br>0 = system HSUSBD BIST Disabled.<br>1 = system HSUSBD BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register                                                                                                                                                                                                                                                      |
| [7]     | <b>PDMABIST</b>    | <b>PDMA BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for PDMA RAM                                                                                                                                                                                                                                                                                                                                                                                                                |

|     |                 |                                                                                                                                                                                                                                                                |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | 0 = system PDMA BIST Disabled.<br>1 = system PDMA BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                |
| [6] | <b>EMCBIST</b>  | <b>EMC BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for EMC RAM<br>0 = system EMC BIST Disabled.<br>1 = system EMC BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                          |
| [5] | <b>SPIMBIST</b> | <b>SPIM BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for SPIM RAM<br>0 = system SPIM BIST Disabled.<br>1 = system SPIM BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                      |
| [4] | <b>USBBIST</b>  | <b>USB BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for USB RAM<br>0 = system USB BIST Disabled.<br>1 = system USB BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                          |
| [3] | <b>CANBIST</b>  | <b>CAN BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for CAN RAM<br>0 = system CAN BIST Disabled.<br>1 = system CAN BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                          |
| [2] | <b>CRBIST</b>   | <b>CACHE BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for CACHE RAM<br>0 = system CACHE BIST Disabled.<br>1 = system CACHE BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                  |
| [1] | <b>SRBIST1</b>  | <b>SRAM Bank1 BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for SRAM bank1.<br>0 = system SRAM bank1 BIST Disabled.<br>1 = system SRAM bank1 BIST Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [0] | <b>SRBIST0</b>  | <b>SRAM Bank0 BIST Enable Bit (Write Protect)</b><br>This bit enables BIST test for SRAM bank0.<br>0 = system SRAM bank0 BIST Disabled.<br>1 = system SRAM bank0 BIST Enabled.<br><b>Note:</b> 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 |  |  |  |  | 0x00xx_00xx |

|          |    |    |         |         |          |           |           |
|----------|----|----|---------|---------|----------|-----------|-----------|
| 31       | 30 | 29 | 28      | 27      | 26       | 25        | 24        |
| Reserved |    |    |         |         |          |           |           |
| 23       | 22 | 21 | 20      | 19      | 18       | 17        | 16        |
| Reserved |    |    | USBBEND | CANBEND | CRBEND   | SRBEND1   | SRBEND0   |
| 15       | 14 | 13 | 12      | 11      | 10       | 9         | 8         |
| Reserved |    |    |         |         |          |           |           |
| 7        | 6  | 5  | 4       | 3       | 2        | 1         | 0         |
| Reserved |    |    | USBBEF  | CANBEF  | CRBISTEF | SRBISTEF1 | SRBISTEF0 |

| Bits    | Description |                                                                                                                                                |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                      |
| [20]    | USBBEND     | <b>USB SRAM BIST Test Finish</b><br>0 = USB SRAM BIST is active.<br>1 = USB SRAM BIST test finish.                                             |
| [19]    | CANBEND     | <b>CAN SRAM BIST Test Finish</b><br>0 = CAN SRAM BIST is active.<br>1 = CAN SRAM BIST test finish.                                             |
| [18]    | CRBEND      | <b>CACHE SRAM BIST Test Finish</b><br>0 = System CACHE RAM BIST is active.<br>1 = System CACHE RAM BIST test finish.                           |
| [17]    | SRBEND1     | <b>2<sup>nd</sup> SRAM BIST Test Finish</b><br>0 = 2 <sup>nd</sup> system SRAM BIST is active.<br>1 = 2 <sup>nd</sup> system SRAM BIST finish. |
| [16]    | SRBEND0     | <b>1<sup>st</sup> SRAM BIST Test Finish</b><br>0 = 1 <sup>st</sup> system SRAM BIST active.<br>1 = 1 <sup>st</sup> system SRAM BIST finish.    |
| [15:5]  | Reserved    | Reserved.                                                                                                                                      |
| [4]     | USBBEF      | <b>USB SRAM BIST Fail Flag</b><br>0 = USB SRAM BIST test pass.<br>1 = USB SRAM BIST test fail.                                                 |
| [3]     | CANBEF      | <b>CAN SRAM BIST Fail Flag</b><br>0 = CAN SRAM BIST test pass.<br>1 = CAN SRAM BIST test fail.                                                 |
| [2]     | CRBISTEF    | <b>CACHE SRAM BIST Fail Flag</b>                                                                                                               |

|     |                  |                                                                                                                                                        |
|-----|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                  | 0 = System CACHE RAM BIST test pass.<br>1 = System CACHE RAM BIST test fail.                                                                           |
| [1] | <b>SRBISTEF1</b> | <b>2<sup>nd</sup> System SRAM BIST Fail Flag</b><br>0 = 2nd system SRAM BIST test pass.<br>1 = 2nd system SRAM BIST test fail.                         |
| [0] | <b>SRBISTEF0</b> | <b>1<sup>st</sup> System SRAM BIST Fail Flag</b><br>0 = 1 <sup>st</sup> system SRAM BIST test pass.<br>1 = 1 <sup>st</sup> system SRAM BIST test fail. |

HIRC Trim Control Register (SYS\_IRCTCTL)

| Register    | Offset      | R/W | Description                |  |  |  | Reset Value |
|-------------|-------------|-----|----------------------------|--|--|--|-------------|
| SYS_IRCTCTL | SYS_BA+0xF0 | R/W | HIRC Trim Control Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [10]    | REFCKSEL    | <b>Reference Clock Selection</b><br>0 = HIRC trim reference from external 32.768 kHz crystal oscillator.<br>1 = HIRC trim reference from internal USB synchronous mode.<br><b>Note:</b> HIRC trim reference clock is 20Khz in test mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [9]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [8]     | CESTOPEN    | <b>Clock Error Stop Enable Bit</b><br>0 = The trim operation is keep going if clock is inaccuracy.<br>1 = The trim operation is stopped if clock is inaccuracy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [7:6]   | RETRYCNT    | <b>Trim Value Update Limitation Count</b><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.<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     | <b>Trim Calculation Loop Selection</b><br>This field defines that trim value calculation is based on how many reference clocks.<br>00 = Trim value calculation is based on average difference in 4 clocks of reference clock.<br>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><b>Note:</b> For example, if LOOPSEL is set as 00, auto trim circuit will calculate trim value based on the average frequency difference in 4 clocks of reference clock. |

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

**HIRC Trim Interrupt Enable Register (SYS\_IRCTIEN)**

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

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

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

**HIRC Trim Interrupt Status Register (SYS\_IRCTISTS)**

| Register     | Offset      | R/W | Description                         |  |  |  | Reset Value |
|--------------|-------------|-----|-------------------------------------|--|--|--|-------------|
| SYS_IRCTISTS | SYS_BA+0xF8 | R/W | HIRC Trim Interrupt Status Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [2]    | CLKERRIF    | <p><b>Clock Error Interrupt Status</b></p> <p>When the frequency of 32.768 kHz external low speed crystal oscillator (LXT) or 12MHz 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</p> <p>Once this bit is set to 1, the auto trim operation stopped and FREQSEL(SYS_IRCTCTL[1:0]) will be cleared to 00 by hardware automatically if CESTOPEN(SYS_IRCTCTL[8]) is set to 1.</p> <p>If this bit is set and CLKEIEN(SYS_IRCTIEN[2]) is high, an interrupt will be triggered to notify the clock frequency is inaccuracy. Write 1 to clear this to 0.</p> <p>0 = Clock frequency is accuracy.<br/>1 = Clock frequency is inaccuracy.</p> |
| [1]    | TFAILIF     | <p><b>Trim Failure Interrupt Status</b></p> <p>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 FREQSEL(SYS_IRCTCTL[1:0]) will be cleared to 00 by hardware automatically.</p> <p>If this bit is set and TFAILIEN(SYS_IRCTIEN[1]) is high, an interrupt will be triggered to notify that HIRC trim value update limitation count was reached. Write 1 to clear this to 0.</p> <p>0 = Trim value update limitation count does not reach.<br/>1 = Trim value update limitation count reached and HIRC frequency still not locked.</p>                                                                           |
| [0]    | FREQLOCK    | <p><b>HIRC Frequency Lock Status</b></p> <p>This bit indicates the HIRC frequency is locked.</p> <p>This is a status bit and doesn't trigger any interrupt</p> <p>Write 1 to clear this to 0. This bit will be set automatically, if the frequency is lock and the RC_TRIM is enabled.</p> <p>0 = The internal high-speed oscillator frequency doesn't lock at 12 MHz yet.<br/>1 = The internal high-speed oscillator frequency locked at 12 MHz.</p>                                                                                                                                                                                                                                                                                                |

**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 “59h”, “16h” “88h” to the register SYS\_REGLCTL address at 0x4000\_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 “0x4000\_0100” to enable register protection.

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

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



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [7:0]  | REGLCTL     | <p><b>Register Lock Control Code (Write Only)</b></p> <p>Some registers have write-protection function. Writing these registers have to disable the protected function by writing the sequence value “59h”, “16h”, “88h” to this field. After this sequence is completed, the REGLCTL bit will be set to 1 and write-protection registers can be normal write.</p> <p><b>REGLCTL[0]</b></p> <p><b>Register Lock Control Disable Index (Read Only)</b></p> <p>0 = Write-protection Enabled for writing protected registers. Any write to the protected register is ignored.</p> <p>1 = Write-protection Disabled for writing protected registers.</p> |

Power Level Control Register (SYS\_PLCTL)

| Register  | Offset       | R/W | Description                  |  |  |  | Reset Value |
|-----------|--------------|-----|------------------------------|--|--|--|-------------|
| SYS_PLCTL | SYS_BA+0x1F8 | R/W | Power Level Control Register |  |  |  | 0x0000_0000 |

|          |    |    |    |    |    |       |    |
|----------|----|----|----|----|----|-------|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25    | 24 |
| LVSPRD   |    |    |    |    |    |       |    |
| 23       | 22 | 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:24] | <b>LVSPRD</b>   | <b>LDO Voltage Scaling Period(Write Protect)</b><br>The LVSPRD value is the period of each LDO voltage rising step.<br>LDO voltage scaling period = (LVSPRD + 1) * 1us.  |
| [23:22] | <b>Reserved</b> | Reserved.                                                                                                                                                                |
| [21:16] | <b>LVSSTEP</b>  | <b>LDO Voltage Scaling Step(Write Protect)</b><br>The LVSSTEP value is LDO voltage rising step.<br>LDO voltage scaling step = (LVSSTEP + 1) * 10mV.                      |
| [15:2]  | <b>Reserved</b> | Reserved.                                                                                                                                                                |
| [1:0]   | <b>PLSEL</b>    | <b>Power Level Select(Write Protect)</b><br>These bits indicate the status of power level.<br>00 = Power level is PL0.<br>01 = Power level is PL1.<br>Others = Reserved. |

**Power Level Status Register (SYS\_PLSTS)**

| Register  | Offset       | R/W | Description                 |  |  |  | Reset Value |
|-----------|--------------|-----|-----------------------------|--|--|--|-------------|
| SYS_PLSTS | SYS_BA+0x1FC | R/W | Power Level Status Register |  |  |  | 0x0000_010X |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                         |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                               |
| [9:8]   | <b>PLSTATUS</b> | <p><b>Power Level Status (Read Only)</b></p> <p>This bit indicates the status of power level.</p> <p>00 = Power level is PL0.<br/>01 = Power level is PL1.<br/>Others = Reserved.</p>                                                                                                                   |
| [7:1]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                               |
| [0]     | <b>PLCBUSY</b>  | <p><b>Power Level Change Busy Bit (Read Only)</b></p> <p>This bit is set by hardware when power level is changing . After power level change is completed, this bit will be cleared automatically by hardware.</p> <p>0 = Core voltage change is completed.<br/>1 = Core voltage change is ongoing.</p> |

**AHB Bus Matrix Priority Control Register (SYS\_AHBMCTL)**

| Register    | Offset       | R/W | Description                              |  |  |  |  | Reset Value |
|-------------|--------------|-----|------------------------------------------|--|--|--|--|-------------|
| SYS_AHBMCTL | SYS_BA+0x400 | R/W | AHB Bus Matrix Priority Control Register |  |  |  |  | 0x0000_0001 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                        |
| [0]    | INTACTEN    | <p><b>Highest AHB Bus Priority of Cortex®-M4 Core Enable Bit (Write Protect)</b></p> <p>Enable Cortex®-M4 Core With Highest AHB Bus Priority In AHB Bus Matrix</p> <p>0 = Round-robin mode.</p> <p>1 = Cortex®-M4 CPU with highest bus priority when interrupt occurred.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |

### 6.2.13 System Timer (SysTick)

The Cortex®-M4 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® Cortex®-M4 Technical Reference Manual” and “ARM® v6-M Architecture Reference Manual”.

### 6.2.14 System Timer Control Register Map

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

| Register                    | Offset      | R/W | Description                         | Reset Value |
|-----------------------------|-------------|-----|-------------------------------------|-------------|
| <b>SYST Base Address:</b>   |             |     |                                     |             |
| <b>SCS_BA = 0xE000_E000</b> |             |     |                                     |             |
| <b>SYST_CTRL</b>            | SCS_BA+0x10 | R/W | SysTick Control and Status Register | 0x0000_0000 |
| <b>SYST_LOAD</b>            | SCS_BA+0x14 | R/W | SysTick Reload Value Register       | 0xFFFF_FFFF |
| <b>SYST_VAL</b>             | SCS_BA+0x18 | R/W | SysTick Current Value Register      | 0xFFFF_FFFF |

## 6.2.14.1 System Timer Control Register Description

**SysTick Control and Status Register (SYST\_CTRL)**

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                            |
| [16]    | COUNTFLAG   | <b>System Tick Counter Flag</b><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      | <b>System Tick Clock Source Selection</b><br>0 = Clock source is the (optional) external reference clock.<br>1 = Core clock used for SysTick.                                                                                                                                                                                                                                        |
| [1]     | TICKINT     | <b>System Tick Interrupt Enabled</b><br>0 = Counting down to 0 does not cause the SysTick exception to be pended. Software can use COUNTFLAG to determine if a count to zero has occurred.<br>1 = Counting down to 0 will cause the SysTick exception to be pended. Clearing the SysTick current value register by a register write in software will not cause SysTick to be pended. |
| [0]     | ENABLE      | <b>System Tick Counter Enabled</b><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 |  |  |  |  | 0xXXXX_XXXX |

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

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

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

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

### 6.2.15 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 little-endian regardless of the endianness state of the processor.

The NVIC supports:

- An implementation-defined number of interrupts, in the range 1-240 interrupts.
- A programmable priority level of 0-16 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.15.1 Exception Model and System Interrupt Map

Table 6.2-9 lists the exception model supported by M480 Series. Software can set 16 levels of priority on some of these exceptions as well as on all interrupts. The highest user-configurable priority is denoted as “0x00” and the lowest priority is denoted as “0xF0” (The 4-LSB always 0). The default priority of all the user-configurable interrupts is “0x00”. 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 0x00000000. Privileged software can write to the VTOR to relocate the vector table start address to a different memory location, in the range 0x00000080 to 0x3FFFFF80,

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             | 0x00000004     | -3           |
| NMI                  | 2             | 0x00000008     | -2           |
| Hard Fault           | 3             | 0x0000000C     | -1           |
| Memory Manager Fault | 4             | 0x00000010     | Configurable |
| Bus Fault            | 5             | 0x00000014     | Configurable |
| Usage Fault          | 6             | 0x00000018     | Configurable |
| Reserved             | 7 ~ 10        |                | Reserved     |

|                               |          |                                   |              |
|-------------------------------|----------|-----------------------------------|--------------|
| <b>SVCall</b>                 | 11       | 0x0000002C                        | Configurable |
| <b>Debug Monitor</b>          | 12       | 0x00000030                        | Configurable |
| <b>Reserved</b>               | 13       |                                   | Reserved     |
| <b>PendSV</b>                 | 14       | 0x00000038                        | Configurable |
| <b>SysTick</b>                | 15       | 0x0000003C                        | Configurable |
| <b>Interrupt (IRQ0 ~ IRQ)</b> | 16 ~ 111 | 0x00000000 +<br>(Vector Number)*4 | Configurable |

Table 6.2-9 Exception Model

| Vector Number | Interrupt Number<br>(Bit In Interrupt Registers) | 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                                                | SRAM_PERR      | SRAM parity check error interrupt                                 |
| 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.0, PD.2 or PE.4 pins                   |
| 27            | 11                                               | EINT1          | External interrupt from PB.0, PD.3 or PE.5 pins                   |
| 28            | 12                                               | EINT2          | External interrupt from PC.0 pin                                  |
| 29            | 13                                               | EINT3          | External interrupt from PD.0 pin                                  |
| 30            | 14                                               | EINT4          | External interrupt from PE.0 pin                                  |
| 31            | 15                                               | EINT5          | External interrupt from PF.0 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                                               | QSPI0_INT      | QSPI0 interrupt                                                   |

|    |    |              |                           |
|----|----|--------------|---------------------------|
| 39 | 23 | SPI0_INT     | SPI0 interrupt            |
| 40 | 24 | BRAKE0_INT   | EPWM0 brake interrupt     |
| 41 | 25 | EPWM0_P0_INT | EPWM0 pair 0 interrupt    |
| 42 | 26 | EPWM0_P1_INT | EPWM0 pair 1 interrupt    |
| 43 | 27 | EPWM0_P2_INT | EPWM0 pair 2 interrupt    |
| 44 | 28 | BRAKE1_INT   | EPWM1 brake interrupt     |
| 45 | 29 | EPWM1_P0_INT | EPWM1 pair 0 interrupt    |
| 46 | 30 | EPWM1_P1_INT | EPWM1 pair 1 interrupt    |
| 47 | 31 | EPWM1_P2_INT | EPWM1 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 | UART0_INT    | UART0 interrupt           |
| 53 | 37 | UART1_INT    | UART1 interrupt           |
| 54 | 38 | I2C0_INT     | I2C0 interrupt            |
| 55 | 39 | I2C1_INT     | I2C1 interrupt            |
| 56 | 40 | PDMA_INT     | PDMA interrupt            |
| 57 | 41 | DAC_INT      | DAC interrupt             |
| 58 | 42 | EADC0_INT    | EADC interrupt source 0   |
| 59 | 43 | EADC1_INT    | EADC interrupt source 1   |
| 60 | 44 | ACMP01_INT   | ACMP0 and ACMP1 interrupt |
| 61 | 45 | Reserved     | Reserved                  |
| 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 | Reserved     | Reserved                  |
| 67 | 51 | SPI1_INT     | SPI1 interrupt            |
| 68 | 52 | SPI2_INT     | SPI2 interrupt            |
| 69 | 53 | USBD_INT     | USB device interrupt      |
| 70 | 54 | USBH_INT     | USB host interrupt        |
| 71 | 55 | USBOTG_INT   | USB OTG interrupt         |
| 72 | 56 | CAN0_INT     | CAN0 interrupt            |
| 73 | 57 | CAN1_INT     | CAN1 interrupt            |

|     |    |             |                                      |
|-----|----|-------------|--------------------------------------|
| 74  | 58 | SC0_INT     | Smart card host 0 interrupt          |
| 75  | 59 | SC1_INT     | Smart card host 1 interrupt          |
| 76  | 60 | SC2_INT     | Smart card host 2 interrupt          |
| 77  | 61 | SC3_INT     | Smart card host 3 interrupt          |
| 78  | 62 | SPI3_INT    | SPI3 interrupt                       |
| 80  | 64 | SDHOST0_INT | SD host 0 interrupt                  |
| 81  | 65 | HSUSBD_INT  | HSUSBD interrupt                     |
| 82  | 66 | EMAC_TX     | Ethernet MAC transmit interrupt      |
| 83  | 67 | EMAC_RX     | Ethernet MAC receive interrupt       |
| 84  | 68 | I2S0_INT    | I2S0 interrupt                       |
| 85  | 69 | Reserved    | Reserved                             |
| 86  | 70 | OPA0_INT    | Analog OP0 interrupt                 |
| 87  | 71 | CRYPTO      | Crypto interrupt                     |
| 88  | 72 | GPG_INT     | External interrupt from PG[15:0] pin |
| 89  | 73 | EINT6       | External interrupt from PG.0 pin     |
| 90  | 74 | UART4_INT   | UART4 interrupt                      |
| 91  | 75 | UART5_INT   | UART5 interrupt                      |
| 92  | 76 | USCI0_INT   | USCI0 interrupt                      |
| 93  | 77 | USCI1_INT   | USCI1 interrupt                      |
| 94  | 78 | BPWM0_INT   | BPWM0 interrupt                      |
| 95  | 79 | BPWM1_INT   | BPWM1 interrupt                      |
| 96  | 80 | SPIM_INT    | SPI Master interrupt                 |
| 97  | 81 | Reserved    | Reserved                             |
| 98  | 82 | I2C2_INT    | I2C2 interrupt                       |
| 99  | 83 | Reserved    | Reserved                             |
| 100 | 84 | QEI0_INT    | QEI0 interrupt                       |
| 101 | 85 | QEI1_INT    | QEI1 interrupt                       |
| 102 | 86 | ECAP0_INT   | ECAP0 interrupt                      |
| 103 | 87 | ECAP1_INT   | ECAP1 interrupt                      |
| 105 | 88 | GPH_INT     | External interrupt from PH[?:0] pin  |
| 105 | 89 | EINT7       | External interrupt from PH.? pin     |
| 106 | 90 | SDHOST1_INT | SD host 1 interrupt                  |
| 107 | 91 | Reserved    | Reserved                             |
| 108 | 92 | HSUSBH_INT  | HSUSBH interrupt                     |
| 109 | 93 | HSOTG_INT   | HSOTG interrupt                      |

Table 6.2-10 Interrupt Number Table

#### 6.2.15.2 Operation Description

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

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

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

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

## 6.2.15.3 NVIC Control Registers

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

| Register                       | Offset                  | R/W | Description                                 | Reset Value |
|--------------------------------|-------------------------|-----|---------------------------------------------|-------------|
| <b>NVIC Base Address:</b>      |                         |     |                                             |             |
| <b>NVIC_BA = 0xE000_E100</b>   |                         |     |                                             |             |
| <b>NVIC_ISER0</b>              | NVIC_BA+0x00            | R/W | IRQ0 ~ IRQ71 Set-Enable Control Register    | 0x0000_0000 |
| <b>NVIC_ISER1</b>              | NVIC_BA+0x04            | R/W | IRQ0 ~ IRQ71 Set-Enable Control Register    | 0x0000_0000 |
| <b>NVIC_ISER2</b>              | NVIC_BA+0x08            | R/W | IRQ0 ~ IRQ71 Set-Enable Control Register    | 0x0000_0000 |
| <b>NVIC_ICER0</b>              | NVIC_BA+0x80            | R/W | IRQ0 ~ IRQ71 Clear-Enable Control Register  | 0x0000_0000 |
| <b>NVIC_ICER1</b>              | NVIC_BA+0x84            | R/W | IRQ0 ~ IRQ71 Clear-Enable Control Register  | 0x0000_0000 |
| <b>NVIC_ICER2</b>              | NVIC_BA+0x88            | R/W | IRQ0 ~ IRQ71 Clear-Enable Control Register  | 0x0000_0000 |
| <b>NVIC_ISPR0</b>              | NVIC_BA+0x100           | R/W | IRQ0 ~ IRQ71 Set-Pending Control Register   | 0x0000_0000 |
| <b>NVIC_ISPR1</b>              | NVIC_BA+0x104           | R/W | IRQ0 ~ IRQ71 Set-Pending Control Register   | 0x0000_0000 |
| <b>NVIC_ISPR2</b>              | NVIC_BA+0x108           | R/W | IRQ0 ~ IRQ71 Set-Pending Control Register   | 0x0000_0000 |
| <b>NVIC_ICPR0</b>              | NVIC_BA+0x180           | R/W | IRQ0 ~ IRQ71 Clear-Pending Control Register | 0x0000_0000 |
| <b>NVIC_ICPR1</b>              | NVIC_BA+0x184           | R/W | IRQ0 ~ IRQ71 Clear-Pending Control Register | 0x0000_0000 |
| <b>NVIC_ICPR2</b>              | NVIC_BA+0x188           | R/W | IRQ0 ~ IRQ71 Clear-Pending Control Register | 0x0000_0000 |
| <b>NVIC_IABR0</b>              | NVIC_BA+0x200           | R/W | IRQ0 ~ IRQ71 Active Bit Register            | 0x0000_0000 |
| <b>NVIC_IABR1</b>              | NVIC_BA+0x204           | R/W | IRQ0 ~ IRQ71 Active Bit Register            | 0x0000_0000 |
| <b>NVIC_IABR2</b>              | NVIC_BA+0x208           | R/W | IRQ0 ~ IRQ71 Active Bit Register            | 0x0000_0000 |
| <b>NVIC_IPRn<br/>n=0,1..17</b> | NVIC_BA+0x300<br>+0x4*n | R/W | IRQ0 ~ IRQ71 Priority Control Register      | 0x0000_0000 |
| <b>STIR</b>                    | NVIC_BA+0xE00           | R/W | Software Trigger Interrupt Registers        | 0x0000_0000 |

IRQ0 ~ IRQ71 Set-enable Control Register (NVIC\_ISER0)

| Register   | Offset       | R/W | Description                              |  |  |  |  | Reset Value |
|------------|--------------|-----|------------------------------------------|--|--|--|--|-------------|
| NVIC_ISER0 | NVIC_BA+0x00 | R/W | IRQ0 ~ IRQ71 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] | SETENA      | <p><b>Interrupt Set Enable Bit</b></p> <p>The NVIC_ISER0-NVIC_ISER2 registers enable interrupts, and show which interrupts are enabled</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Interrupt Enabled.</p> <p>Read Operation:</p> <p>0 = Interrupt Disabled.</p> <p>1 = Interrupt Enabled.</p> |

IRQ0 ~ IRQ71 Set-enable Control Register (NVIC\_ISER1)

| Register   | Offset       | R/W | Description                              |  |  |  |  | Reset Value |
|------------|--------------|-----|------------------------------------------|--|--|--|--|-------------|
| NVIC_ISER1 | NVIC_BA+0x04 | R/W | IRQ0 ~ IRQ71 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] | SETENA      | <p><b>Interrupt Set Enable Bit</b></p> <p>The NVIC_ISER0-NVIC_ISER2 registers enable interrupts, and show which interrupts are enabled</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Interrupt Enabled.</p> <p>Read Operation:</p> <p>0 = Interrupt Disabled.</p> <p>1 = Interrupt Enabled.</p> |

IRQ0 ~ IRQ71 Set-enable Control Register (NVIC\_ISER2)

| Register   | Offset       | R/W | Description                              |  |  |  |  | Reset Value |
|------------|--------------|-----|------------------------------------------|--|--|--|--|-------------|
| NVIC_ISER2 | NVIC_BA+0x08 | R/W | IRQ0 ~ IRQ71 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] | SETENA      | <p><b>Interrupt Set Enable Bit</b></p> <p>The NVIC_ISER0-NVIC_ISER2 registers enable interrupts, and show which interrupts are enabled</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Interrupt Enabled.</p> <p>Read Operation:</p> <p>0 = Interrupt Disabled.</p> <p>1 = Interrupt Enabled.</p> |

IRQ0 ~ IRQ71 Clear-enable Control Register (NVIC\_ICER0)

| Register   | Offset       | R/W | Description                                |  |  |  |  | Reset Value |
|------------|--------------|-----|--------------------------------------------|--|--|--|--|-------------|
| NVIC_ICER0 | NVIC_BA+0x80 | R/W | IRQ0 ~ IRQ71 Clear-Enable Control Register |  |  |  |  | 0x0000_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] | CALENA      | <p><b>Interrupt Clear Enable Bit</b></p> <p>The NVIC_ICER0-NVIC_ICER2 registers disable interrupts, and show which interrupts are enabled.</p> <p>Write Operation:</p> <p>0 = No effect.<br/>1 = Interrupt Disabled.</p> <p>Read Operation:</p> <p>0 = Interrupt Disabled.<br/>1 = Interrupt Enabled.</p> |

IRQ0 ~ IRQ71 Clear-enable Control Register (NVIC\_ICER1)

| Register   | Offset       | R/W | Description                                |  |  |  |  | Reset Value |
|------------|--------------|-----|--------------------------------------------|--|--|--|--|-------------|
| NVIC_ICER1 | NVIC_BA+0x84 | R/W | IRQ0 ~ IRQ71 Clear-Enable Control Register |  |  |  |  | 0x0000_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] | CALENA      | <p><b>Interrupt Clear Enable Bit</b></p> <p>The NVIC_ICER0-NVIC_ICER2 registers disable interrupts, and show which interrupts are enabled.</p> <p>Write Operation:</p> <p>0 = No effect.<br/>1 = Interrupt Disabled.</p> <p>Read Operation:</p> <p>0 = Interrupt Disabled.<br/>1 = Interrupt Enabled.</p> |

IRQ0 ~ IRQ71 Clear-enable Control Register (NVIC\_ICER2)

| Register   | Offset       | R/W | Description                                |  |  |  |  | Reset Value |
|------------|--------------|-----|--------------------------------------------|--|--|--|--|-------------|
| NVIC_ICER2 | NVIC_BA+0x88 | R/W | IRQ0 ~ IRQ71 Clear-Enable Control Register |  |  |  |  | 0x0000_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] | CALENA      | <p><b>Interrupt Clear Enable Bit</b></p> <p>The NVIC_ICER0-NVIC_ICER2 registers disable interrupts, and show which interrupts are enabled.</p> <p>Write Operation:</p> <p>0 = No effect.<br/>1 = Interrupt Disabled.</p> <p>Read Operation:</p> <p>0 = Interrupt Disabled.<br/>1 = Interrupt Enabled.</p> |

IRQ0 ~ IRQ71 Set-pending Control Register (NVIC\_ISPR0)

| Register   | Offset        | R/W | Description                               |  |  |  |  | Reset Value |
|------------|---------------|-----|-------------------------------------------|--|--|--|--|-------------|
| NVIC_ISPR0 | NVIC_BA+0x100 | R/W | IRQ0 ~ IRQ71 Set-Pending Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description    |                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>SETPEND</b> | <p><b>Interrupt Set-pending</b></p> <p>The NVIC_ISPR0-NVIC_ISPR2 registers force interrupts into the pending state, and show which interrupts are pending</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Changes interrupt state to pending.</p> <p>Read Operation:</p> <p>0 = Interrupt is not pending.</p> <p>1 = Interrupt is pending.</p> |

IRQ0 ~ IRQ71 Set-pending Control Register (NVIC\_ISPR1)

| Register   | Offset        | R/W | Description                               |  |  |  |  | Reset Value |
|------------|---------------|-----|-------------------------------------------|--|--|--|--|-------------|
| NVIC_ISPR1 | NVIC_BA+0x104 | R/W | IRQ0 ~ IRQ71 Set-Pending Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description    |                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>SETPEND</b> | <p><b>Interrupt Set-pending</b></p> <p>The NVIC_ISPR0-NVIC_ISPR2 registers force interrupts into the pending state, and show which interrupts are pending</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Changes interrupt state to pending.</p> <p>Read Operation:</p> <p>0 = Interrupt is not pending.</p> <p>1 = Interrupt is pending.</p> |

IRQ0 ~ IRQ71 Set-pending Control Register (NVIC\_ISPR2)

| Register   | Offset        | R/W | Description                               |  |  |  |  | Reset Value |
|------------|---------------|-----|-------------------------------------------|--|--|--|--|-------------|
| NVIC_ISPR2 | NVIC_BA+0x108 | R/W | IRQ0 ~ IRQ71 Set-Pending Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description    |                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>SETPEND</b> | <p><b>Interrupt Set-pending</b></p> <p>The NVIC_ISPR0-NVIC_ISPR2 registers force interrupts into the pending state, and show which interrupts are pending</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Changes interrupt state to pending.</p> <p>Read Operation:</p> <p>0 = Interrupt is not pending.</p> <p>1 = Interrupt is pending.</p> |

IRQ0 ~ IRQ71 Clear-pending Control Register (NVIC\_ICPR0)

| Register   | Offset        | R/W | Description                                 |  |  |  |  | Reset Value |
|------------|---------------|-----|---------------------------------------------|--|--|--|--|-------------|
| NVIC_ICPR0 | NVIC_BA+0x180 | R/W | IRQ0 ~ IRQ71 Clear-Pending Control Register |  |  |  |  | 0x0000_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] | CALPEND     | <p><b>Interrupt Clear-pending</b></p> <p>The NVIC_ICPR0-NVIC_ICPR2 registers remove the pending state from interrupts, and show which interrupts are pending</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Removes pending state an interrupt.</p> <p>Read Operation:</p> <p>0 = Interrupt is not pending.</p> <p>1 = Interrupt is pending.</p> |

IRQ0 ~ IRQ71 Clear-pending Control Register (NVIC\_ICPR1)

| Register   | Offset        | R/W | Description                                 |  |  |  |  | Reset Value |
|------------|---------------|-----|---------------------------------------------|--|--|--|--|-------------|
| NVIC_ICPR1 | NVIC_BA+0x184 | R/W | IRQ0 ~ IRQ71 Clear-Pending Control Register |  |  |  |  | 0x0000_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] | CALPEND     | <p><b>Interrupt Clear-pending</b></p> <p>The NVIC_ICPR0-NVIC_ICPR2 registers remove the pending state from interrupts, and show which interrupts are pending</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Removes pending state an interrupt.</p> <p>Read Operation:</p> <p>0 = Interrupt is not pending.</p> <p>1 = Interrupt is pending.</p> |

IRQ0 ~ IRQ71 Clear-pending Control Register (NVIC\_ICPR2)

| Register   | Offset        | R/W | Description                                 |  |  |  |  | Reset Value |
|------------|---------------|-----|---------------------------------------------|--|--|--|--|-------------|
| NVIC_ICPR2 | NVIC_BA+0x188 | R/W | IRQ0 ~ IRQ71 Clear-Pending Control Register |  |  |  |  | 0x0000_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] | CALPEND     | <p><b>Interrupt Clear-pending</b></p> <p>The NVIC_ICPR0-NVIC_ICPR2 registers remove the pending state from interrupts, and show which interrupts are pending</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Removes pending state an interrupt.</p> <p>Read Operation:</p> <p>0 = Interrupt is not pending.</p> <p>1 = Interrupt is pending.</p> |

IRQ0 ~ IRQ71 Active Bit Register (NVIC\_IABR0)

| Register   | Offset        | R/W | Description                      |  |  |  |  | Reset Value |
|------------|---------------|-----|----------------------------------|--|--|--|--|-------------|
| NVIC_IABR0 | NVIC_BA+0x200 | R/W | IRQ0 ~ IRQ71 Active Bit Register |  |  |  |  | 0x0000_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      | <p><b>Interrupt Active Flags</b></p> <p>The NVIC_IABR0-NVIC_IABR2 registers indicate which interrupts are active.</p> <p>0 = interrupt not active.</p> <p>1 = interrupt active.</p> |

IRQ0 ~ IRQ71 Active Bit Register (NVIC\_IABR1)

| Register   | Offset        | R/W | Description                      |  |  |  |  | Reset Value |
|------------|---------------|-----|----------------------------------|--|--|--|--|-------------|
| NVIC_IABR1 | NVIC_BA+0x204 | R/W | IRQ0 ~ IRQ71 Active Bit Register |  |  |  |  | 0x0000_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      | <b>Interrupt Active Flags</b><br>The NVIC_IABR0-NVIC_IABR2 registers indicate which interrupts are active.<br>0 = interrupt not active.<br>1 = interrupt active. |

IRQ0 ~ IRQ71 Active Bit Register (NVIC\_IABR2)

| Register   | Offset        | R/W | Description                      |  |  |  |  | Reset Value |
|------------|---------------|-----|----------------------------------|--|--|--|--|-------------|
| NVIC_IABR2 | NVIC_BA+0x208 | R/W | IRQ0 ~ IRQ71 Active Bit Register |  |  |  |  | 0x0000_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      | <p><b>Interrupt Active Flags</b></p> <p>The NVIC_IABR0-NVIC_IABR2 registers indicate which interrupts are active.</p> <p>0 = interrupt not active.</p> <p>1 = interrupt active.</p> |

IRQ0 ~ IRQ71 Interrupt Priority Register (NVIC\_IPRn)

| Register               | Offset                  | R/W | Description                            | Reset Value |
|------------------------|-------------------------|-----|----------------------------------------|-------------|
| NVIC_IPRn<br>n=0,1..17 | NVIC_BA+0x300<br>+0x4*n | R/W | IRQ0 ~ IRQ71 Priority Control Register | 0x0000_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:28] | PRI_4n_3    | <b>Priority of IRQ_4n+3</b><br>“0” denotes the highest priority and “15” denotes the lowest priority |
| [27:24] | Reserved    | Reserved.                                                                                            |
| [23:20] | PRI_4n_2    | <b>Priority of IRQ_4n+2</b><br>“0” denotes the highest priority and “15” denotes the lowest priority |
| [19:16] | Reserved    | Reserved.                                                                                            |
| [15:12] | PRI_4n_1    | <b>Priority of IRQ_4n+1</b><br>“0” denotes the highest priority and “15” denotes the lowest priority |
| [11:8]  | Reserved    | Reserved.                                                                                            |
| [7:4]   | PRI_4n_0    | <b>Priority of IRQ_4n+0</b><br>“0” denotes the highest priority and “15” denotes the lowest priority |
| [3:0]   | Reserved    | Reserved.                                                                                            |

**Software Trigger Interrupt Register (STIR)**

| Register | Offset        | R/W | Description                          |  |  |  |  | Reset Value |
|----------|---------------|-----|--------------------------------------|--|--|--|--|-------------|
| STIR     | NVIC_BA+0xE00 | R/W | Software Trigger Interrupt Registers |  |  |  |  | 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 |    |    |    |    |    |    | INTID |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0     |
| INTID    |    |    |    |    |    |    |       |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                               |
| [8:0]  | INTID       | <p><b>Interrupt ID</b></p> <p>Write to the STIR To Generate An Interrupt from Software</p> <p>When the USERSETPEND bit in the SCR is set to 1, unprivileged software can access the STIR</p> <p>Interrupt ID of the interrupt to trigger, in the range 0-63. For example, a value of 0x03 specifies interrupt IRQ3.</p> |

## 6.2.15.4 NMI Control Registers

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

| Register                                                | Offset      | R/W | Description                          | Reset Value |
|---------------------------------------------------------|-------------|-----|--------------------------------------|-------------|
| <b>NMI Base Address:</b><br><b>NMI_BA = 0x4000_0300</b> |             |     |                                      |             |
| <b>NMIEN</b>                                            | NMI_BA+0x00 | R/W | NMI Source Interrupt Enable Register | 0x0000_0000 |
| <b>NMISTS</b>                                           | NMI_BA+0x04 | R   | NMI source interrupt Status Register | 0x0000_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  | UART0_INT | EINT5    | EINT4   | EINT3     | EINT2     | EINT1   | EINT0  |
| 7          | 6         | 5        | 4       | 3         | 2         | 1       | 0      |
| TAMPER_INT | RTC_INT   | Reserved | CLKFAIL | SRAM_PERR | PWRWU_INT | IRC_INT | BODOUT |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                           |
| [15]    | UART1_INT   | <p><b>UART1 NMI Source Enable (Write Protect)</b><br/>           0 = UART1 NMI source Disabled.<br/>           1 = UART1 NMI source Enabled.<br/> <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                  |
| [14]    | UART0_INT   | <p><b>UART0 NMI Source Enable (Write Protect)</b><br/>           0 = UART0 NMI source Disabled.<br/>           1 = UART0 NMI source Enabled.<br/> <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                  |
| [13]    | EINT5       | <p><b>External Interrupt From PF.0 Pin NMI Source Enable (Write Protect)</b><br/>           0 = External interrupt from PF.0 pin NMI source Disabled.<br/>           1 = External interrupt from PF.0 pin NMI source Enabled.<br/> <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [12]    | EINT4       | <p><b>External Interrupt From PE.0 Pin NMI Source Enable (Write Protect)</b><br/>           0 = External interrupt from PE.0 pin NMI source Disabled.<br/>           1 = External interrupt from PE.0 pin NMI source Enabled.<br/> <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [11]    | EINT3       | <p><b>External Interrupt From PD.0 Pin NMI Source Enable (Write Protect)</b><br/>           0 = External interrupt from PD.0 pin NMI source Disabled.<br/>           1 = External interrupt from PD.0 pin NMI source Enabled.<br/> <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [10]    | EINT2       | <p><b>External Interrupt From PC.0 Pin NMI Source Enable (Write Protect)</b><br/>           0 = External interrupt from PC.0 pin NMI source Disabled.<br/>           1 = External interrupt from PC.0 pin NMI source Enabled.<br/> <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [9]     | EINT1       | <b>External Interrupt From PB.0, PD.3 or PE.5 Pin NMI Source Enable (Write Protect)</b>                                                                                                                                                                                                                             |

|     |            |                                                                                                                                                                                                                                                                                                                              |
|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |            | 0 = External interrupt from PB.0, PD.3 or PE.5 pin NMI source Disabled.<br>1 = External interrupt from PB.0, PD.3 or PE.5 pin NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                            |
| [8] | EINT0      | <b>External Interrupt From PA.0, PD.2 or PE.4 Pin NMI Source Enable (Write Protect)</b><br>0 = External interrupt from PA.0, PD.2 or PE.4 pin NMI source Disabled.<br>1 = External interrupt from PA.0, PD.2 or PE.4 pin NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [7] | TAMPER_INT | <b>TAMPER_INT NMI Source Enable (Write Protect)</b><br>0 = Backup register tamper detected interrupt.NMI source Disabled.<br>1 = Backup register tamper detected interrupt.NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                               |
| [6] | RTC_INT    | <b>RTC NMI Source Enable (Write Protect)</b><br>0 = RTC NMI source Disabled.<br>1 = RTC NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                  |
| [5] | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                    |
| [4] | CLKFAIL    | <b>Clock Fail Detected NMI Source Enable (Write Protect)</b><br>0 = Clock fail detected interrupt NMI source Disabled.<br>1 = Clock fail detected interrupt NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                              |
| [3] | SRAM_PERR  | <b>SRAM ParityCheck Error NMI Source Enable (Write Protect)</b><br>0 = SRAM parity check error NMI source Disabled.<br>1 = SRAM parity check error NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                       |
| [2] | PWRWU_INT  | <b>Power-down Mode Wake-up NMI Source Enable (Write Protect)</b><br>0 = Power-down mode wake-up NMI source Disabled.<br>1 = Power-down mode wake-up NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                      |
| [1] | IRC_INT    | <b>IRC TRIM NMI Source Enable (Write Protect)</b><br>0 = IRC TRIM NMI source Disabled.<br>1 = IRC TRIM NMI source Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                   |
| [0] | BODOUT     | <b>BOD NMI Source Enable (Write Protect)</b><br>0 = BOD NMI source Disabled.<br>1 = BOD NMI source Enabled.<br><b>Note:</b> 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 |  |  |  | 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  | UART0_INT | EINT5    | EINT4   | EINT3     | EINT2     | EINT1   | EINT0  |
| 7          | 6         | 5        | 4       | 3         | 2         | 1       | 0      |
| TAMPER_INT | RTC_INT   | Reserved | CLKFAIL | SRAM_PERR | PWRWU_INT | IRC_INT | BODOUT |

| Bits    | Description |                                                                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                            |
| [15]    | UART1_INT   | <b>UART1 Interrupt Flag (Read Only)</b><br>0 = UART1 interrupt is deasserted.<br>1 = UART1 interrupt is asserted.                                                                                                                    |
| [14]    | UART0_INT   | <b>UART0 Interrupt Flag (Read Only)</b><br>0 = UART1 interrupt is deasserted.<br>1 = UART1 interrupt is asserted.                                                                                                                    |
| [13]    | EINT5       | <b>External Interrupt From PF.0 Pin Interrupt Flag (Read Only)</b><br>0 = External Interrupt from PF.0 interrupt is deasserted.<br>1 = External Interrupt from PF.0 interrupt is asserted.                                           |
| [12]    | EINT4       | <b>External Interrupt From PE.0 Pin Interrupt Flag (Read Only)</b><br>0 = External Interrupt from PE.0 interrupt is deasserted.<br>1 = External Interrupt from PE.0 interrupt is asserted.                                           |
| [11]    | EINT3       | <b>External Interrupt From PD.0 Pin Interrupt Flag (Read Only)</b><br>0 = External Interrupt from PD.0 interrupt is deasserted.<br>1 = External Interrupt from PD.0 interrupt is asserted.                                           |
| [10]    | EINT2       | <b>External Interrupt From PC.0 Pin Interrupt Flag (Read Only)</b><br>0 = External Interrupt from PC.0 interrupt is deasserted.<br>1 = External Interrupt from PC.0 interrupt is asserted.                                           |
| [9]     | EINT1       | <b>External Interrupt From PB.0, PD.3 or PE.5 Pin Interrupt Flag (Read Only)</b><br>0 = External Interrupt from PB.0, PD.3 or PE.5 interrupt is deasserted.<br>1 = External Interrupt from PB.0, PD.3 or PE.5 interrupt is asserted. |
| [8]     | EINT0       | <b>External Interrupt From PA.0, PD.2 or PE.4 Pin Interrupt Flag (Read Only)</b><br>0 = External Interrupt from PA.0, PD.2 or PE.4 interrupt is deasserted.<br>1 = External Interrupt from PA.0, PD.2 or PE.4 interrupt is asserted. |

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

#### 6.2.15.5 AHB Bus Matrix Priority Control Register

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

| Register                    | Offset     | R/W | Description                              | Reset Value |
|-----------------------------|------------|-----|------------------------------------------|-------------|
| <b>AHB Base Address:</b>    |            |     |                                          |             |
| <b>AHB_BA = 0x4000_0400</b> |            |     |                                          |             |
| AHBMCTL                     | 0x40000400 | R/W | AHB Bus Matrix Priority Control Register | 0x0000_0001 |

AHB Bus Matrix Priority Control Register (AHBMCTL)

| Register | Offset     | R/W | Description                              |  |  |  |  | Reset Value |
|----------|------------|-----|------------------------------------------|--|--|--|--|-------------|
| AHBMCTL  | 0x40000400 | R/W | AHB Bus Matrix Priority Control Register |  |  |  |  | 0x0000_0001 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [0]    | INTACTEN    | <p><b>Highest AHB Bus Priority of Cortex®-M4 Core Enable Bit (Write Protect)</b></p> <p>Enable Cortex®-M4 Core With Highest AHB Bus Priority In AHB Bus Matrix</p> <p>0 = Round-robin mode.</p> <p>1 = Cortex®-M4 CPU with highest bus priority when interrupt occurs.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |

### 6.2.16 System Control Register

The Cortex®-M4 status and operation mode control are managed by System Control Registers. Including CPUID, Cortex®-M4 interrupt priority and Cortex®-M4 power management can be controlled through these system control registers.

For more detailed information, please refer to the “ARM® Cortex™-M4 Technical Reference Manual” and “ARM® v6-M Architecture Reference Manual”.

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

| Register                    | Offset       | R/W | Description                                      | Reset Value |
|-----------------------------|--------------|-----|--------------------------------------------------|-------------|
| <b>SCR Base Address:</b>    |              |     |                                                  |             |
| <b>SCS_BA = 0xE000_E000</b> |              |     |                                                  |             |
| <b>ICSR</b>                 | SCS_BA+0xD04 | R/W | Interrupt Control and State Register             | 0x0000_0000 |
| <b>AIRCR</b>                | SCS_BA+0xD0C | R/W | Application Interrupt and Reset Control Register | 0xFA05_0000 |
| <b>SCR</b>                  | SCS_BA+0xD10 | R/W | System Control Register                          | 0x0000_0000 |
| <b>SHPR1</b>                | SCS_BA+0xD18 | R/W | System Handler Priority Register 1               | 0x0000_0000 |
| <b>SHPR2</b>                | SCS_BA+0xD1C | R/W | System Handler Priority Register 2               | 0x0000_0000 |
| <b>SHPR3</b>                | SCS_BA+0xD20 | R/W | System Handler Priority Register 3               | 0x0000_0000 |

Interrupt Control State Register (ICSR)

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

| 31          | 30          | 29         | 28        | 27            | 26        | 25            | 24       |
|-------------|-------------|------------|-----------|---------------|-----------|---------------|----------|
| NMIPENDSET  | Reserved    |            | PENDSVSET | PENDSVRTC_CAL | PENDSTSET | PENDSTRTC_CAL | Reserved |
| 23          | 22          | 21         | 20        | 19            | 18        | 17            | 16       |
| ISRPREEMPT  | ISRPENDIN_G | Reserved   |           |               |           | VECTPENDING   |          |
| 15          | 14          | 13         | 12        | 11            | 10        | 9             | 8        |
| VECTPENDING |             |            |           | RETTOBASE     | Reserved  |               |          |
| 7           | 6           | 5          | 4         | 3             | 2         | 1             | 0        |
| Reserved    |             | VECTACTIVE |           |               |           |               |          |

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

|         |               |                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [26]    | PENDSTSET     | <b>SysTick Exception Set-pending Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Change SysTick exception state to pending.<br>Read Operation:<br>0 = SysTick exception is not pending.<br>1 = SysTick exception is pending.                                                                                                                                                                |
| [25]    | PENDSTRTC_CAL | <b>SysTick Exception Clear-pending Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Remove the pending state from the SysTick exception.<br><b>Note:</b> This is a write only bit. To clear the PENDST bit, you must "write 0 to PENDSTSET and write 1 to PENDSTRTC_CAL" at the same time.                                                                                                   |
| [24]    | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                        |
| [23]    | ISRPREEMPT    | <b>Interrupt Preempt Bit (Read Only)</b><br>If set, a pending exception will be serviced on exit from the debug halt state.                                                                                                                                                                                                                                                                      |
| [22]    | ISR PENDING   | <b>Interrupt Pending Flag, Excluding NMI and Faults (Read Only)</b><br>0 = Interrupt not pending.<br>1 = Interrupt pending.                                                                                                                                                                                                                                                                      |
| [21:18] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                        |
| [17:12] | VECTPENDING   | <b>Number of the Highest Pended Exception</b><br>Indicate the Exception Number of the Highest Priority Pending Enabled Exception<br>0 = no pending exceptions.<br>Nonzero = the exception number of the highest priority pending enabled exception.<br>The value indicated by this field includes the effect of the BASEPRI and FAULTMASK registers, but not any effect of the PRIMASK register. |
| [11]    | RETTOBASE     | <b>Preempted Active Exceptions Indicator</b><br>Indicate whether There are Preempted Active Exceptions<br>0 = there are preempted active exceptions to execute.<br>1 = there are no active exceptions, or the currently-executing exception is the only active exception.                                                                                                                        |
| [10:7]  | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                        |
| [6:0]   | VECTACTIVE    | <b>Number of the Current Active Exception</b><br>0 = Thread mode.<br>Non-zero = The exception number of the currently active exception.                                                                                                                                                                                                                                                          |

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

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

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

| Bits    | Description   |                                                                                                                                                                                                                                                                                                             |
|---------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | VECTORKEY     | <b>Register Access Key</b><br>When writing this register, this field should be 0x05FA, otherwise the write action will be unpredictable.<br>The VECTORKEY filed is used to prevent accidental write to this register from resetting the system or clearing of the exception status.                         |
| [15]    | ENDIANNES     | <b>Data Endianness</b><br>0 = Little-endian.<br>1 = Big-endian.                                                                                                                                                                                                                                             |
| [14:11] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                   |
| [10:8]  | PRIGROUP      | <b>Interrupt Priority Grouping</b><br>This field determines the Split Of Group priority from subpriority,                                                                                                                                                                                                   |
| [7:3]   | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                   |
| [2]     | SYSRESETREQ   | <b>System Reset Request</b><br>Writing This Bit to 1 Will Cause A Reset Signal To Be Asserted To The Chip And Indicate A Reset Is Requested<br>This bit is write only and self-cleared as part of the reset sequence.                                                                                       |
| [1]     | VECTCLRACTIVE | <b>Exception Active Status Clear Bit</b><br>Setting This Bit To 1 Will Clears All Active State Information For Fixed And Configurable Exceptions<br>This bit is write only and can only be written when the core is halted.<br><b>Note:</b> It is the debugger's responsibility to re-initialize the stack. |
| [0]     | VECTRESET     | Reserved.                                                                                                                                                                                                                                                                                                   |

| PRIGROUP | Binary Point | Group Priority Bits | Subpriority Bits | Number Of Priorities | Group | Subpriorities |
|----------|--------------|---------------------|------------------|----------------------|-------|---------------|
| 0b000    | bxxxxxxxx.y  | [7:1]               | [0]              | 128                  |       | 2             |
| 0b001    | bxxxxxx.yy   | [7:2]               | [1:0]            | 64                   |       | 4             |
| 0b010    | bxxxxx.yyy   | [7:3]               | [2:0]            | 32                   |       | 8             |
| 0b011    | bxxxx.yyyy   | [7:4]               | [3:0]            | 16                   |       | 16            |
| 0b100    | bxxx.yyyyy   | [7:5]               | [4:0]            | 8                    |       | 32            |
| 0b101    | bxx.yyyyyy   | [7:6]               | [5:0]            | 4                    |       | 64            |
| 0b110    | bx.yyyyyyy   | [7]                 | [6:0]            | 2                    |       | 128           |
| 0b111    | b.yyyyyyyy   | None                | [7:0]            | 1                    |       | 256           |

Table 6.2-11 Priority Grouping

**System Control Register (SCR)**

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

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [4]    | SEVONPEND   | <p><b>Send Event on Pending</b></p> <p>0 = Only enabled interrupts or events can wake up the processor, while disabled interrupts are excluded.</p> <p>1 = Enabled events and all interrupts, including disabled interrupts, can wake up the processor.</p> <p>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.</p> <p>The processor also wakes up on execution of an SEV instruction or an external event.</p> |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [2]    | SLEEPDEEP   | <p><b>Processor Deep Sleep and Sleep Mode Selection</b></p> <p>Control whether the Processor Uses Sleep Or Deep Sleep as its Low Power Mode.</p> <p>0 = Sleep.</p> <p>1 = Deep sleep.</p>                                                                                                                                                                                                                                                                                                                                                                         |
| [1]    | SLEEPONEXIT | <p><b>Sleep-on-exit Enable Control</b></p> <p>This bit indicate Sleep-On-Exit when Returning from Handler Mode to Thread Mode.</p> <p>0 = Do not sleep when returning to Thread mode.</p> <p>1 = Enter sleep, or deep sleep, on return from an ISR to Thread mode.</p> <p>Setting this bit to 1 enables an interrupt driven application to avoid returning to an empty main application.</p>                                                                                                                                                                      |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**System Handler Priority Register 1 (SHPR1)**

| Register | Offset       | R/W | Description                        |  |  |  |  | Reset Value |
|----------|--------------|-----|------------------------------------|--|--|--|--|-------------|
| SHPR1    | SCS_BA+0xD18 | R/W | System Handler Priority Register 1 |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                          |
|---------|-------------|------------------------------------------|
| [31:24] | Reserved    | Reserved.                                |
| [23:16] | PRI_6       | Priority of system handler 6, UsageFault |
| [15:8]  | PRI_5       | Priority of system handler 5, BusFault   |
| [7:0]   | PRI_4       | Priority of system handler 4, MemManage  |

**System Handler Priority Register 2 (SHPR2)**

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

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

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

**System Handler Priority Register 3 (SHPR3)**

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

|        |    |    |    |    |    |    |    |          |
|--------|----|----|----|----|----|----|----|----------|
| 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 |          |
| PRI_15 |    |    |    |    |    |    |    | Reserved |
| 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |          |
| PRI_14 |    |    |    |    |    |    |    | 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      | <b>Priority of System Handler 15 – SysTick</b><br>“0” denotes the highest priority and “3” denotes the lowest priority. |
| [29:24] | Reserved    | Reserved.                                                                                                               |
| [23:22] | PRI_14      | <b>Priority of System Handler 14 – PendSV</b><br>“0” denotes the highest priority and “3” denotes the lowest priority.  |
| [21:0]  | Reserved    | Reserved.                                                                                                               |

## 6.3 Clock Controller

### 6.3.1 Overview

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



**Note:** For USB High-speed application, HXT should be 12 MHz.

Figure 6.3-1 Clock Generator Global View Diagram

### 6.3.2 Clock Generator

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

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



Figure 6.3-2 Clock Generator Block Diagram

### 6.3.3 System Clock and SysTick Clock

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



Figure 6.3-3 System Clock Block Diagrams

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

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

Figure 6.3-4 shows The HXT clock stops detection and system clock switches to HIRC procedure



Figure 6.3-4 HXT Stop Protect Procedure

The clock source of SysTick in Cortex®-M4 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

Each peripheral clock has its own clock source selection. Refer to the CLK\_CLKSEL1, CLK\_CLKSEL2 and CLK\_CLKSEL3 register.

### 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 these clocks, which still keep active, are listed below:

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

### 6.3.6 Clock Output

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

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

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



Figure 6.3-6 Clock Output Block Diagram

### 6.3.7 USB Clock Source

The clock sources of USB 1.0 and 2.0 systems are generated from USB2.0 PHY clock or programmable PLL output. The generated clocks are shown in Figure 6.3-7.



Figure 6.3-7 USB Clock Source

### 6.3.8 HXT clock

The High Speed Crystal (HXT) can be generated from two possible clock sources:

- HXT external crystal oscillator
- HXT user external clock



Figure 6.3-8 HXT Clock Sources

#### External source (HXT OSC Mode)

The clock sources can be input from the external pin (PF.3).

When writing 1 to CFGXT1(CONFIG0[27]), HXT work as crystal mode. PF.2 and PF.3 are configured as external high speed crystal (HXT) pins. When writing 0 to CFGXT1 (CONFIG0[27]), HXT work as external clock mode. PF.3 is configured as external clock input pin. PF.3 MFP should be setting as GPIO mode. The DC characteristic of XT1\_IN is the same as GPIO.

### 6.3.9 Register Map

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

| Register                    | Offset      | R/W | Description                                            | Reset Value |
|-----------------------------|-------------|-----|--------------------------------------------------------|-------------|
| <b>CLK Base Address:</b>    |             |     |                                                        |             |
| <b>CLK_BA = 0x4000_0200</b> |             |     |                                                        |             |
| <b>CLK_PWRCTL</b>           | CLK_BA+0x00 | R/W | System Power-down Control Register                     | 0x0000_XX1X |
| <b>CLK_AHBCLK</b>           | CLK_BA+0x04 | R/W | AHB Devices Clock Enable Control Register              | 0x0000_8004 |
| <b>CLK_APBCLK0</b>          | CLK_BA+0x08 | R/W | APB Devices Clock Enable Control Register 0            | 0x0000_0001 |
| <b>CLK_APBCLK1</b>          | CLK_BA+0x0C | R/W | APB Devices Clock Enable Control Register 1            | 0x0000_0000 |
| <b>CLK_CLKSEL0</b>          | CLK_BA+0x10 | R/W | Clock Source Select Control Register 0                 | 0x00F3_013X |
| <b>CLK_CLKSEL1</b>          | CLK_BA+0x14 | R/W | Clock Source Select Control Register 1                 | 0xBF77_7703 |
| <b>CLK_CLKSEL2</b>          | CLK_BA+0x18 | R/W | Clock Source Select Control Register 2                 | 0x0000_03AB |
| <b>CLK_CLKSEL3</b>          | CLK_BA+0x1C | R/W | Clock Source Select Control Register 3                 | 0xFF00_003F |
| <b>CLK_CLKDIV0</b>          | CLK_BA+0x20 | R/W | Clock Divider Number Register 0                        | 0x0000_0000 |
| <b>CLK_CLKDIV1</b>          | CLK_BA+0x24 | R/W | Clock Divider Number Register 1                        | 0x0000_0000 |
| <b>CLK_CLKDIV3</b>          | CLK_BA+0x2C | R/W | Clock Divider Number Register 3                        | 0x0000_0000 |
| <b>CLK_CLKDIV4</b>          | CLK_BA+0x30 | R/W | Clock Divider Number Register 4                        | 0x0000_0000 |
| <b>CLK_PCLKDIV</b>          | CLK_BA+0x34 | R/W | APB Clock Divider Register                             | 0x0000_0000 |
| <b>CLK_PLLCTL</b>           | CLK_BA+0x40 | R/W | PLL Control Register                                   | 0x0005_C02E |
| <b>CLK_STATUS</b>           | CLK_BA+0x50 | R   | Clock Status Monitor Register                          | 0x0000_00XX |
| <b>CLK_CLKOCTL</b>          | CLK_BA+0x60 | R/W | Clock Output Control Register                          | 0x0000_0000 |
| <b>CLK_CLKDCTL</b>          | CLK_BA+0x70 | R/W | Clock Fail Detector Control Register                   | 0x0000_0000 |
| <b>CLK_CLKDSTS</b>          | CLK_BA+0x74 | R/W | Clock Fail Detector Status Register                    | 0x0000_0000 |
| <b>CLK_CDUPB</b>            | CLK_BA+0x78 | R/W | Clock Frequency Range Detector Upper Boundary Register | 0x0000_0000 |
| <b>CLK_CDLOWB</b>           | CLK_BA+0x7C | R/W | Clock Frequency Range Detector Lower Boundary Register | 0x0000_0000 |
| <b>CLK_PMUCTL</b>           | CLK_BA+0x90 | R/W | Power Manager Control Register                         | 0x0000_0080 |
| <b>CLK_PMUSTS</b>           | CLK_BA+0x94 | R/W | Power Manager Status Register                          | 0x0000_0000 |
| <b>CLK_LDOCTL</b>           | CLK_BA+0x98 | R/W | LDO Control Register                                   | 0x0000_0000 |
| <b>CLK_SWKDBCTL</b>         | CLK_BA+0x9C | R/W | Standby Power-down Wake-up De-bounce Control Register  | 0x0000_0000 |
| <b>CLK_PASWKCTL</b>         | CLK_BA+0xA0 | R/W | GPA Standby Power-down Wake-up Control Register        | 0x0000_0000 |
| <b>CLK_PBSWKCTL</b>         | CLK_BA+0xA4 | R/W | GPB Standby Power-down Wake-up Control Register        | 0x0000_0000 |
| <b>CLK_PCSWKCTL</b>         | CLK_BA+0xA8 | R/W | GPC Standby Power-down Wake-up Control Register        | 0x0000_0000 |

|              |             |     |                                                 |             |
|--------------|-------------|-----|-------------------------------------------------|-------------|
| CLK_PDSWKCTL | CLK_BA+0xAC | R/W | GPD Standby Power-down Wake-up Control Register | 0x0000_0000 |
| CLK_IOPDCTL  | CLK_BA+0xB0 | R/W | GPIO Standby Power-down Control Register        | 0x0000_0000 |

### 6.3.10 Register Description

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

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [17:16] | HIRCSTBS    | <b>HIRC Stable Count Select (Write Protect )</b><br>00 = HIRC stable count = 64 clocks.<br>01 = HIRC stable count = 24 clocks.<br>Others: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [13]    | HXTTBEN     | <b>HXT Crystal TURBO Mode (Write Protect)</b><br>This is a protected register. Please refer to open lock sequence to program it.<br>0 = HXT Crystal TURBO mode Disabled.<br>1 = HXT Crystal TURBO mode Enabled.                                                                                                                                                                                                                                                                                                                                                                          |
| [12]    | HXTSELTYP   | <b>HXT Crystal Type Select Bit (Write Protect)</b><br>This is a protected register. Please refer to open lock sequence to program it.<br>0 = Select INV type.<br>1 = Select GM type.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                     |
| [11:10] | HXTGAIN     | <b>HXT Gain Control Bit (Write Protect)</b><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>00 = HXT frequency is lower than from 8 MHz.<br>01 = HXT frequency is from 8 MHz to 12 MHz.<br>10 = HXT frequency is from 12 MHz to 16 MHz.<br>11 = HXT frequency is higher than 16 MHz.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [9:8]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | <b>PDEN</b>    | <b>System Power-down Enable (Write Protect)</b><br>When this bit is set to 1, Power-down mode is enabled and chip keeps active till the CPU sleep mode is also active and then the chip enters Power-down mode.<br>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 and the HIRC will be disabled in this mode, but LXT and LIRC are not controlled by Power-down mode.<br>In Power-down mode, the PLL and system clock are disabled, and ignored the clock source selection. The clocks of peripheral are not controlled by Power-down mode, if the peripheral clock source is from LXT or LIRC.<br>0 = Chip will not enter Power-down mode after CPU sleep command WFI.<br>1 = Chip enters Power-down mode after CPU sleep command WFI.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [6] | <b>PDWKIF</b>  | <b>Power-down Mode Wake-up Interrupt Status</b><br>Set by “Power-down wake-up event”, it 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><b>Note1:</b> Write 1 to clear the bit to 0.<br><b>Note2:</b> This bit works only if PDWKIEN (CLK_PWRCTL[5]) set to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [5] | <b>PDWKIEN</b> | <b>Power-down Mode Wake-up Interrupt Enable Bit (Write Protect)</b><br>0 = Power-down mode wake-up interrupt Disabled.<br>1 = Power-down mode wake-up interrupt Enabled.<br><b>Note1:</b> The interrupt will occur when both PDWKIF and PDWKIEN are high.<br><b>Note2:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4] | <b>PDWKDLY</b> | <b>Enable the Wake-up Delay Counter (Write Protect)</b><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~24 MHz external high speed crystal oscillator (HXT), and 256 clock cycles when chip works at 12 MHz internal high speed RC oscillator (HIRC).<br>0 = Clock cycles delay Disabled.<br>1 = Clock cycles delay Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                             |
| [3] | <b>LIRCEN</b>  | <b>LIRC Enable Bit (Write Protect)</b><br>0 = 10 kHz internal low speed RC oscillator (LIRC) Disabled.<br>1 = 10 kHz internal low speed RC oscillator (LIRC) Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [2] | <b>HIRCEN</b>  | <b>HIRC Enable Bit (Write Protect)</b><br>0 = 12 MHz internal high speed RC oscillator (HIRC) Disabled.<br>1 = 12 MHz internal high speed RC oscillator (HIRC) Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [1] | <b>LXTEN</b>   | <b>LXT Enable Bit (Write Protect)</b><br>0 = 32.768 kHz external low speed crystal (LXT) Disabled.<br>1 = 32.768 kHz external low speed crystal (LXT) Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [0] | <b>HXTEN</b>   | <b>HXT Enable Bit (Write Protect)</b><br>The bit default value is set by flash controller user configuration register CONFIG0 [26:24]. When the default clock source is from HXT, this bit is set to 1 automatically.<br>0 = 4~24 MHz external high speed crystal (HXT) Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

|  |  |                                                         |
|--|--|---------------------------------------------------------|
|  |  | 1 = 4~24 MHz external high speed crystal (HXT) Enabled. |
|--|--|---------------------------------------------------------|

**Note:** This bit is write protected. Refer to the SYS\_REGLCTL register.

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 |  |  |  | 0x0000_8004 |

|          |          |          |          |          |            |          |          |
|----------|----------|----------|----------|----------|------------|----------|----------|
| 31       | 30       | 29       | 28       | 27       | 26         | 25       | 24       |
| Reserved |          |          |          |          |            |          |          |
| 23       | 22       | 21       | 20       | 19       | 18         | 17       | 16       |
| Reserved |          |          |          |          |            | SDH1CKEN | USBHCKEN |
| 15       | 14       | 13       | 12       | 11       | 10         | 9        | 8        |
| FMCIDLE  | SPIMCKEN | Reserved | CRPTCKEN | Reserved | HSUSBDCKEN | Reserved |          |
| 7        | 6        | 5        | 4        | 3        | 2          | 1        | 0        |
| CRCCKEN  | SDH0CKEN | EMACCKEN | Reserved | EBICKEN  | ISPCKEN    | PDMACKEN | Reserved |

| Bits    | Description |                                                                                                                                                                             |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                   |
| [17]    | SDH1CKEN    | <b>SD1 Controller Clock Enable Bit</b><br>0 = SD1 engine clock Disabled.<br>1 = SD1 engine clock Enabled.                                                                   |
| [16]    | USBHCKEN    | <b>USB HOST Controller Clock Enable Bit</b><br>0 = USB HOST peripheral clock Disabled.<br>1 = USB HOST peripheral clock Enabled.                                            |
| [15]    | FMCIDLE     | <b>Flash Memory Controller Clock Enable Bit in IDLE Mode</b><br>0 = FMC clock Disabled when chip is under IDLE mode.<br>1 = FMC clock Enabled when chip is under IDLE mode. |
| [14]    | SPIMCKEN    | <b>SPIM Controller Clock Enable Bit</b><br>0 = SPIM controller clock Disabled.<br>1 = SPIM controller clock Enabled.                                                        |
| [13]    | Reserved    | Reserved.                                                                                                                                                                   |
| [12]    | CRPTCKEN    | <b>Cryptographic Accelerator Clock Enable Bit</b><br>0 = Cryptographic Accelerator clock Disabled.<br>1 = Cryptographic Accelerator clock Enabled.                          |
| [11]    | Reserved    | Reserved.                                                                                                                                                                   |
| [10]    | HSUSBDCKEN  | <b>HSUSB Device Clock Enable Bit</b><br>0 = HSUSB device controller clock Disabled.<br>1 = HSUSB device controller clock Enabled.                                           |
| [9:8]   | Reserved    | Reserved.                                                                                                                                                                   |
| [7]     | CRCCKEN     | <b>CRC Generator Controller Clock Enable Bit</b>                                                                                                                            |

|     |                 |                                                                                                                                                |
|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | 0 = CRC peripheral clock Disabled.<br>1 = CRC peripheral clock Enabled.                                                                        |
| [6] | <b>SDH0CKEN</b> | <b>SD0 Controller Clock Enable Bit</b><br>0 = SD0 engine clock Disabled.<br>1 = SD0 engine clock Enabled.                                      |
| [5] | <b>EMACCKEN</b> | <b>Ethernet Controller Clock Enable Bit</b><br>0 = Ethernet Controller engine clock Disabled.<br>1 = Ethernet Controller engine clock Enabled. |
| [4] | <b>Reserved</b> | Reserved.                                                                                                                                      |
| [3] | <b>EBICKEN</b>  | <b>EBI Controller Clock Enable Bit</b><br>0 = EBI peripheral clock Disabled.<br>1 = EBI peripheral clock Enabled.                              |
| [2] | <b>ISPCKEN</b>  | <b>Flash ISP Controller Clock Enable Bit</b><br>0 = Flash ISP peripheral clock Disabled.<br>1 = Flash ISP peripheral clock Enabled.            |
| [1] | <b>PDMACKEN</b> | <b>PDMA Controller Clock Enable Bit</b><br>0 = PDMA peripheral clock Disabled.<br>1 = PDMA peripheral clock Enabled.                           |
| [0] | <b>Reserved</b> | Reserved.                                                                                                                                      |

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

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

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

|            |           |           |           |           |           |           |           |
|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| 31         | 30        | 29        | 28        | 27        | 26        | 25        | 24        |
| Reserved   | HSOTGCKEN | I2S0CKEN  | EADCCKEN  | USBDCKEN  | OTGCKEN   | CAN1CKEN  | CAN0CKEN  |
| 23         | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
| Reserved   |           | UART5CKEN | UART4CKEN | UART3CKEN | UART2CKEN | UART1CKEN | UART0CKEN |
| 15         | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
| SPI2CKEN   | SPI1CKEN  | SPI0CKEN  | QSPI0CKEN | Reserved  | I2C2CKEN  | I2C1CKEN  | I2C0CKEN  |
| 7          | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| ACMP01CKEN | CLKOCKEN  | TMR3CKEN  | TMR2CKEN  | TMR1CKEN  | TMR0CKEN  | RTCKEN    | WDTCKEN   |

| Bits    | Description |                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                                |
| [30]    | HSOTGCKEN   | <b>HSUSB OTG Clock Enable Bit</b><br>0 = HSUSB OTG clock Disabled.<br>1 = HSUSB OTG clock Enabled.                       |
| [29]    | I2S0CKEN    | <b>I<sup>2</sup>S0 Clock Enable Bit</b><br>0 = I <sup>2</sup> S0 Clock Disabled.<br>1 = I <sup>2</sup> S0 Clock Enabled. |
| [28]    | EADCCKEN    | <b>Enhanced Analog-digital-converter (EADC) Clock Enable Bit</b><br>0 = EADC clock Disabled.<br>1 = EADC clock Enabled.  |
| [27]    | USBDCKEN    | <b>USB Device Clock Enable Bit</b><br>0 = USB Device clock Disabled.<br>1 = USB Device clock Enabled.                    |
| [26]    | OTGCKEN     | <b>USB OTG Clock Enable Bit</b><br>0 = USB OTG clock Disabled.<br>1 = USB OTG clock Enabled.                             |
| [25]    | CAN1CKEN    | <b>CAN1 Clock Enable Bit</b><br>0 = CAN1 clock Disabled.<br>1 = CAN1 clock Enabled.                                      |
| [24]    | CAN0CKEN    | <b>CAN0 Clock Enable Bit</b><br>0 = CAN0 clock Disabled.<br>1 = CAN0 clock Enabled.                                      |
| [23:22] | Reserved    | Reserved.                                                                                                                |

|      |                   |                                                                                                                                        |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| [21] | <b>UART5CKEN</b>  | <b>UART5 Clock Enable Bit</b><br>0 = UART5 clock Disabled.<br>1 = UART5 clock Enabled.                                                 |
| [20] | <b>UART4CKEN</b>  | <b>UART4 Clock Enable Bit</b><br>0 = UART4 clock Disabled.<br>1 = UART4 clock Enabled.                                                 |
| [19] | <b>UART3CKEN</b>  | <b>UART3 Clock Enable Bit</b><br>0 = UART3 clock Disabled.<br>1 = UART3 clock Enabled.                                                 |
| [18] | <b>UART2CKEN</b>  | <b>UART2 Clock Enable Bit</b><br>0 = UART2 clock Disabled.<br>1 = UART2 clock Enabled.                                                 |
| [17] | <b>UART1CKEN</b>  | <b>UART1 Clock Enable Bit</b><br>0 = UART1 clock Disabled.<br>1 = UART1 clock Enabled.                                                 |
| [16] | <b>UART0CKEN</b>  | <b>UART0 Clock Enable Bit</b><br>0 = UART0 clock Disabled.<br>1 = UART0 clock Enabled.                                                 |
| [15] | <b>SPI2CKEN</b>   | <b>SPI2 Clock Enable Bit</b><br>0 = SPI2 clock Disabled.<br>1 = SPI2 clock Enabled.                                                    |
| [14] | <b>SPI1CKEN</b>   | <b>SPI1 Clock Enable Bit</b><br>0 = SPI1 clock Disabled.<br>1 = SPI1 clock Enabled.                                                    |
| [13] | <b>SPI0CKEN</b>   | <b>SPI0 Clock Enable Bit</b><br>0 = SPI0 clock Disabled.<br>1 = SPI0 clock Enabled.                                                    |
| [12] | <b>QSPI0CKEN</b>  | <b>QSPI0 Clock Enable Bit</b><br>0 = QSPI0 clock Disabled.<br>1 = QSPI0 clock Enabled.                                                 |
| [11] | <b>Reserved</b>   | Reserved.                                                                                                                              |
| [10] | <b>I2C2CKEN</b>   | <b>I2C2 Clock Enable Bit</b><br>0 = I2C2 clock Disabled.<br>1 = I2C2 clock Enabled.                                                    |
| [9]  | <b>I2C1CKEN</b>   | <b>I2C1 Clock Enable Bit</b><br>0 = I2C1 clock Disabled.<br>1 = I2C1 clock Enabled.                                                    |
| [8]  | <b>I2C0CKEN</b>   | <b>I2C0 Clock Enable Bit</b><br>0 = I2C0 clock Disabled.<br>1 = I2C0 clock Enabled.                                                    |
| [7]  | <b>ACMP01CKEN</b> | <b>Analog Comparator 0/1 Clock Enable Bit</b><br>0 = Analog comparator 0/1 clock Disabled.<br>1 = Analog comparator 0/1 clock Enabled. |

|     |                 |                                                                                                                                                                                                                                                                                                                                                           |
|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | <b>CLKOCKEN</b> | <b>CLKO Clock Enable Bit</b><br>0 = CLKO clock Disabled.<br>1 = CLKO clock Enabled.                                                                                                                                                                                                                                                                       |
| [5] | <b>TMR3CKEN</b> | <b>Timer3 Clock Enable Bit</b><br>0 = Timer3 clock Disabled.<br>1 = Timer3 clock Enabled.                                                                                                                                                                                                                                                                 |
| [4] | <b>TMR2CKEN</b> | <b>Timer2 Clock Enable Bit</b><br>0 = Timer2 clock Disabled.<br>1 = Timer2 clock Enabled.                                                                                                                                                                                                                                                                 |
| [3] | <b>TMR1CKEN</b> | <b>Timer1 Clock Enable Bit</b><br>0 = Timer1 clock Disabled.<br>1 = Timer1 clock Enabled.                                                                                                                                                                                                                                                                 |
| [2] | <b>TMR0CKEN</b> | <b>Timer0 Clock Enable Bit</b><br>0 = Timer0 clock Disabled.<br>1 = Timer0 clock Enabled.                                                                                                                                                                                                                                                                 |
| [1] | <b>RTCCKEN</b>  | <b>Real-time-clock APB Interface Clock Enable Bit</b><br>This bit is used to control the RTC APB clock only. The RTC peripheral clock source is selected from RTCSEL(CLK_CLKSEL3[8]). It can be selected to 32.768 kHz external low speed crystal or 10 kHz internal low speed RC oscillator (LIRC).<br>0 = RTC clock Disabled.<br>1 = RTC clock Enabled. |
| [0] | <b>WDTCKEN</b>  | <b>Watchdog Timer Clock Enable Bit (Write Protect)</b><br>0 = Watchdog timer clock Disabled.<br>1 = Watchdog timer clock Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                         |

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

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

| Register    | Offset      | R/W | Description                                 |  |  |  | Reset Value |
|-------------|-------------|-----|---------------------------------------------|--|--|--|-------------|
| CLK_APBCLK1 | CLK_BA+0x0C | R/W | APB Devices Clock Enable Control Register 1 |  |  |  | 0x0000_0000 |

|          |          |          |         |           |           |           |           |
|----------|----------|----------|---------|-----------|-----------|-----------|-----------|
| 31       | 30       | 29       | 28      | 27        | 26        | 25        | 24        |
| Reserved | OPACKEN  | Reserved |         | ECAP1CKEN | ECAP0CKEN | Reserved  |           |
| 23       | 22       | 21       | 20      | 19        | 18        | 17        | 16        |
| QEI1CKEN | QEI0CKEN | Reserved |         | BPWM1CKEN | BPWM0CKEN | EPWM1CKEN | EPWM0CKEN |
| 15       | 14       | 13       | 12      | 11        | 10        | 9         | 8         |
| Reserved |          |          | DACCKEN | Reserved  |           | USCI1CKEN | USCI0CKEN |
| 7        | 6        | 5        | 4       | 3         | 2         | 1         | 0         |
| Reserved | SPI3CKEN | Reserved |         |           | SC2CKEN   | SC1CKEN   | SC0CKEN   |

| Bits    | Description |                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                       |
| [30]    | OPACKEN     | <b>OP Amplifier (OPA) Clock Enable Bit</b><br>0 = OPA clock Disabled.<br>1 = OPA clock Enabled. |
| [29:28] | Reserved    | Reserved.                                                                                       |
| [27]    | ECAP1CKEN   | <b>ECAP1 Clock Enable Bit</b><br>0 = ECAP1 clock Disabled.<br>1 = ECAP1 clock Enabled.          |
| [26]    | ECAP0CKEN   | <b>ECAP0 Clock Enable Bit</b><br>0 = ECAP0 clock Disabled.<br>1 = ECAP0 clock Enabled.          |
| [25:24] | Reserved    | Reserved.                                                                                       |
| [23]    | QEI1CKEN    | <b>QEI1 Clock Enable Bit</b><br>0 = QEI1 clock Disabled.<br>1 = QEI1 clock Enabled.             |
| [22]    | QEI0CKEN    | <b>QEI0 Clock Enable Bit</b><br>0 = QEI0 clock Disabled.<br>1 = QEI0 clock Enabled.             |
| [21:20] | Reserved    | Reserved.                                                                                       |
| [19]    | BPWM1CKEN   | <b>BPWM1 Clock Enable Bit</b><br>0 = BPWM1 clock Disabled.<br>1 = BPWM1 clock Enabled.          |
| [18]    | BPWM0CKEN   | <b>BPWM0 Clock Enable Bit</b>                                                                   |

|         |                  |                                                                                        |
|---------|------------------|----------------------------------------------------------------------------------------|
|         |                  | 0 = BPWM0 clock Disabled.<br>1 = BPWM0 clock Enabled.                                  |
| [17]    | <b>EPWM1CKEN</b> | <b>EPWM1 Clock Enable Bit</b><br>0 = EPWM1 clock Disabled.<br>1 = EPWM1 clock Enabled. |
| [16]    | <b>EPWM0CKEN</b> | <b>EPWM0 Clock Enable Bit</b><br>0 = EPWM0 clock Disabled.<br>1 = EPWM0 clock Enabled. |
| [15:13] | <b>Reserved</b>  | Reserved.                                                                              |
| [12]    | <b>DACCKEN</b>   | <b>DAC Clock Enable Bit</b><br>0 = DAC clock Disabled.<br>1 = DAC clock Enabled.       |
| [11:10] | <b>Reserved</b>  | Reserved.                                                                              |
| [9]     | <b>USCI1CKEN</b> | <b>USCI1 Clock Enable Bit</b><br>0 = USCI1 clock Disabled.<br>1 = USCI1 clock Enabled. |
| [8]     | <b>USCI0CKEN</b> | <b>USCI0 Clock Enable Bit</b><br>0 = USCI0 clock Disabled.<br>1 = USCI0 clock Enabled. |
| [7]     | <b>Reserved</b>  | Reserved.                                                                              |
| [6]     | <b>SPI3CKEN</b>  | <b>SPI3 Clock Enable Bit</b><br>0 = SPI3 clock Disabled.<br>1 = SPI3 clock Enabled.    |
| [5:3]   | <b>Reserved</b>  | Reserved.                                                                              |
| [2]     | <b>SC2CKEN</b>   | <b>SC2 Clock Enable Bit</b><br>0 = SC2 clock Disabled.<br>1 = SC2 clock Enabled.       |
| [1]     | <b>SC1CKEN</b>   | <b>SC1 Clock Enable Bit</b><br>0 = SC1 clock Disabled.<br>1 = SC1 clock Enabled.       |
| [0]     | <b>SC0CKEN</b>   | <b>SC0 Clock Enable Bit</b><br>0 = SC0 clock Disabled.<br>1 = SC0 clock Enabled.       |

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

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [23:22] | SDH1SEL     | <b>SD1 Engine Clock Source Selection (Write Protect)</b><br>00 = Clock source from HXT clock.<br>01 = Clock source from PLL clock.<br>10 = Clock source from HCLK.<br>11 = Clock source from HIRC clock.                                                                                                                                                                                                                                                                                                                           |
| [21:20] | SDH0SEL     | <b>SD0 Engine Clock Source Selection (Write Protect)</b><br>00 = Clock source from HXT clock.<br>01 = Clock source from PLL clock.<br>10 = Clock source from HCLK.<br>11 = Clock source from HIRC clock.                                                                                                                                                                                                                                                                                                                           |
| [19:6]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [5:3]   | STCLKSEL    | <b>Cortex®-M4 SysTick Clock Source Selection (Write Protect)</b><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><b>Note1:</b> 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><b>Note2:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [2:0]   | HCLKSEL     | <b>HCLK Clock Source Selection (Write Protect)</b><br>Before clock switching, the related clock sources (both pre-select and new-select) must be turned on.<br>000 = Clock source from HXT.                                                                                                                                                                                                                                                                                                                                        |

|  |  |                                                                                                                                                                                                                                                   |
|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | <p>001 = Clock source from LXT.<br/>010 = Clock source from PLL.<br/>011 = Clock source from LIRC.<br/>111= Clock source from HIRC.<br/>Other = Reserved.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**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+0x14 | R/W | Clock Source Select Control Register 1 |  |  |  | 0xBF77_7703 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | WWDTSEL     | <b>Window Watchdog Timer Clock Source Selection</b><br>10 = Clock source from HCLK/2048.<br>11 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).<br>Others = Reserved.                                                                                                                                  |
| [29:28] | CLKOSEL     | <b>Clock Divider Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>10 = Clock source from HCLK.<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [27:26] | UART1SEL    | <b>UART1 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).          |
| [25:24] | UART0SEL    | <b>UART0 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).          |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                 |
| [22:20] | TMR3SEL     | <b>TIMER3 Clock Source Selection</b><br>000 = Clock source from 4~24 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.                                                                               |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 011 = Clock source from external clock TM3 pin.<br>101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).<br>111 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).<br>Others = Reserved.                                                                                                                                                                                                                                                |
| [19]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [18:16] | <b>TMR2SEL</b>  | <b>TIMER2 Clock Source Selection</b><br>000 = Clock source from 4~24 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 TM2 pin.<br>101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).<br>111 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).<br>Others = Reserved. |
| [15]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [14:12] | <b>TMR1SEL</b>  | <b>TIMER1 Clock Source Selection</b><br>000 = Clock source from 4~24 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 TM1 pin.<br>101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).<br>111 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).<br>Others = Reserved. |
| [11]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [10:8]  | <b>TMR0SEL</b>  | <b>TIMER0 Clock Source Selection</b><br>000 = Clock source from 4~24 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 TM0 pin.<br>101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).<br>111 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).<br>Others = Reserved. |
| [7:2]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [1:0]   | <b>WDTSEL</b>   | <b>Watchdog Timer Clock Source Selection (Write Protect)</b><br>00 = Reserved.<br>01 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>10 = Clock source from HCLK/2048.<br>11 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                             |

**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+0x18 | R/W | Clock Source Select Control Register 2 |  |  |  | 0x0000_03AB |

|          |    |         |    |          |    |          |          |
|----------|----|---------|----|----------|----|----------|----------|
| 31       | 30 | 29      | 28 | 27       | 26 | 25       | 24       |
| Reserved |    |         |    |          |    |          |          |
| 23       | 22 | 21      | 20 | 19       | 18 | 17       | 16       |
| Reserved |    |         |    |          |    |          |          |
| 15       | 14 | 13      | 12 | 11       | 10 | 9        | 8        |
| Reserved |    | SPI3SEL |    | SPI2SEL  |    | BPWM1SEL | BPWM0SEL |
| 7        | 6  | 5       | 4  | 3        | 2  | 1        | 0        |
| SPI1SEL  |    | SPI0SEL |    | QSPI0SEL |    | EPWM1SEL | EPWM0SEL |

| Bits    | Description |                                                                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [13:12] | SPI3SEL     | <b>SPI3 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from PCLK0.<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [11:10] | SPI2SEL     | <b>SPI2 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from PCLK1.<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [9]     | BPWM1SEL    | <b>BPWM1 Clock Source Selection</b><br>The peripheral clock source of BPWM1 is defined by BPWM1SEL.<br>0 = Clock source from PLL.<br>1 = Clock source from PCLK1.                                                                                              |
| [8]     | BPWM0SEL    | <b>BPWM0 Clock Source Selection</b><br>The peripheral clock source of BPWM0 is defined by BPWM0SEL.<br>0 = Clock source from PLL.<br>1 = Clock source from PCLK0.                                                                                              |
| [7:6]   | SPI1SEL     | <b>SPI1 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from PCLK0.<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [5:4]   | SPI0SEL     | <b>SPI0 Clock Source Selection</b>                                                                                                                                                                                                                             |

|       |                 |                                                                                                                                                                                                                                                                 |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | 00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from PCLK1.<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).                                        |
| [3:2] | <b>QSPI0SEL</b> | <b>QSPI0 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from PCLK0.<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [1]   | <b>EPWM1SEL</b> | <b>EPWM1 Clock Source Selection</b><br>The peripheral clock source of EPWM1 is defined by EPWM1SEL.<br>0 = Clock source from PLL.<br>1 = Clock source from PCLK1.                                                                                               |
| [0]   | <b>EPWM0SEL</b> | <b>EPWM0 Clock Source Selection</b><br>The peripheral clock source of EPWM0 is defined by EPWM0SEL.<br>0 = Clock source from PLL.<br>1 = Clock source from PCLK0.                                                                                               |

**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+0x1C | R/W | Clock Source Select Control Register 3 |  |  |  | 0xFF00_003F |

|          |    |          |    |          |    |          |        |
|----------|----|----------|----|----------|----|----------|--------|
| 31       | 30 | 29       | 28 | 27       | 26 | 25       | 24     |
| UART5SEL |    | UART4SEL |    | UART3SEL |    | UART2SEL |        |
| 23       | 22 | 21       | 20 | 19       | 18 | 17       | 16     |
| Reserved |    |          |    |          |    | I2S0SEL  |        |
| 15       | 14 | 13       | 12 | 11       | 10 | 9        | 8      |
| Reserved |    |          |    |          |    |          | RTCSEL |
| 7        | 6  | 5        | 4  | 3        | 2  | 1        | 0      |
| Reserved |    | SC2SEL   |    | SC1SEL   |    | SC0SEL   |        |

| Bits    | Description                                                                                                                                                                                                                                                                                                      |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | <b>UART5 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [29:28] | <b>UART4 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [27:26] | <b>UART3 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [25:24] | <b>UART2 Clock Source Selection</b><br>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br>01 = Clock source from PLL.<br>10 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC). |
| [23:18] | Reserved                                                                                                                                                                                                                                                                                                         |
| [17:16] | <b>I<sup>2</sup>S0 Clock Source Selection</b><br>00 = Clock source from HXT clock.<br>01 = Clock source from PLL clock.<br>10 = Clock source from PCLK0.                                                                                                                                                         |

|        |                 |                                                                                                                                                                                                                                                                             |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                 | 11 = Clock source from HIRC clock.                                                                                                                                                                                                                                          |
| [15:9] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                   |
| [8]    | <b>RTCSEL</b>   | <p><b>RTC Clock Source Selection</b></p> <p>0 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br/>1 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).</p>                                                                     |
| [7:6]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                   |
| [5:4]  | <b>SC2SEL</b>   | <p><b>SC2 Clock Source Selection</b></p> <p>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br/>01 = Clock source from PLL.<br/>10 = Clock source from PCLK0.<br/>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).</p> |
| [3:2]  | <b>SC1SEL</b>   | <p><b>SC0 Clock Source Selection</b></p> <p>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br/>01 = Clock source from PLL.<br/>10 = Clock source from PCLK1.<br/>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).</p> |
| [1:0]  | <b>SC0SEL</b>   | <p><b>SC0 Clock Source Selection</b></p> <p>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT).<br/>01 = Clock source from PLL.<br/>10 = Clock source from PCLK0.<br/>11 = Clock source from 12 MHz internal high speed RC oscillator (HIRC).</p> |

Clock Divider Number Register 0 (CLK\_CLKDIV0)

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

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

| Bits    | Description     |                                                                                                                                      |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <b>SDH0DIV</b>  | <b>SD0 Clock Divide Number From SD0 Clock Source</b><br>SD0 clock frequency = (SD0 clock source frequency) / (SDH0DIV + 1).          |
| [23:16] | <b>EADCDIV</b>  | <b>EADC Clock Divide Number From EADC Clock Source</b><br>EADC clock frequency = (EADC clock source frequency) / (EADCDIV + 1).      |
| [15:12] | <b>UART1DIV</b> | <b>UART1 Clock Divide Number From UART1 Clock Source</b><br>UART1 clock frequency = (UART1 clock source frequency) / (UART1DIV + 1). |
| [11:8]  | <b>UART0DIV</b> | <b>UART0 Clock Divide Number From UART0 Clock Source</b><br>UART0 clock frequency = (UART0 clock source frequency) / (UART0DIV + 1). |
| [7:4]   | <b>USBDIV</b>   | <b>USB Clock Divide Number From PLL Clock</b><br>USB clock frequency = (PLL frequency) / (USBDIV + 1).                               |
| [3:0]   | <b>HCLKDIV</b>  | <b>HCLK Clock Divide Number From HCLK Clock Source</b><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+0x24 | R/W | Clock Divider Number Register 1 | 0x0000_0000 |

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

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

**Clock Divider Number Register 3 (CLK\_CLKDIV3)**

| Register    | Offset      | R/W | Description                     | Reset Value |
|-------------|-------------|-----|---------------------------------|-------------|
| CLK_CLKDIV3 | CLK_BA+0x2C | R/W | Clock Divider Number Register 3 | 0x0000_0000 |



| Bits    | Description     |                                                                                                                             |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <b>SDH1DIV</b>  | <b>SD1 Clock Divide Number From SD1 Clock Source</b><br>SD1 clock frequency = (SD1 clock source frequency) / (SDH1DIV + 1). |
| [23:16] | <b>EMACDIV</b>  | <b>Ethernet Clock Divide Number Form HCLK</b><br>EMAC MDCLK clock frequency = (HCLK) / (EMACDIV + 1).                       |
| [15:0]  | <b>Reserved</b> | Reserved.                                                                                                                   |

**Clock Divider Number Register 4 (CLK\_CLKDIV4)**

| Register    | Offset      | R/W | Description                     | Reset Value |
|-------------|-------------|-----|---------------------------------|-------------|
| CLK_CLKDIV4 | CLK_BA+0x30 | R/W | Clock Divider Number Register 4 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                            |
| [15:12] | UART5DIV    | <b>UART5 Clock Divide Number From UART5 Clock Source</b><br>UART5 clock frequency = (UART5 clock source frequency) / (UART5DIV + 1). |
| [11:8]  | UART4DIV    | <b>UART4 Clock Divide Number From UART4 Clock Source</b><br>UART4 clock frequency = (UART4 clock source frequency) / (UART4DIV + 1). |
| [7:4]   | UART3DIV    | <b>UART3 Clock Divide Number From UART3 Clock Source</b><br>UART3 clock frequency = (UART3 clock source frequency) / (UART3DIV + 1). |
| [3:0]   | UART2DIV    | <b>UART2 Clock Divide Number From UART2 Clock Source</b><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 |  |  |  |  | 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 | APB1DIV |    |    | Reserved | APB0DIV |    |    |  |

| Bits   | Description |                                                                                                                                                                                                                                                                     |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                           |
| [6:4]  | APB1DIV     | <b>APB1 Clock Divider</b><br>APB1 clock can be divided from HCLK<br>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>Others: Reserved.<br><b>Note:</b> PCLK must be less than 96 MHz. |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                           |
| [2:0]  | APB0DIV     | <b>APB0 Clock Divider</b><br>APB0 clock can be divided from HCLK<br>000: PCLK0 = HCLK.<br>001: PCLK0 = 1/2 HCLK.<br>010: PCLK0 = 1/4 HCLK.<br>011: PCLK0 = 1/8 HCLK.<br>100: PCLK0 = 1/16 HCLK.<br>Others: Reserved.<br><b>Note:</b> PCLK must be less than 96 MHz. |

**PLL Control Register (CLK\_PLLCTL)**

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| [28]    | BANDSEL     | <b>PLL Stable Counter Selection (Write Protect)</b><br>0 = PLL low band frequency select. (FVCO range is 200 MHz ~ 400 MHz)<br>1 = PLL high band frequency select. (FVCO range is 400 MHz ~ 500 MHz)<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                 |
| [23]    | STBSEL      | <b>PLL Stable Counter Selection (Write Protect)</b><br>0 = PLL stable time is 6144 PLL source clock (suitable for source clock is equal to or less than 12 MHz).<br>1 = PLL stable time is 12288 PLL source clock (suitable for source clock is larger than 12 MHz).<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [22:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| [19]    | PLLSRC      | <b>PLL Source Clock Selection (Write Protect)</b><br>0 = PLL source clock from 4~24 MHz external high-speed crystal oscillator (HXT).<br>1 = PLL source clock from 12 MHz internal high-speed oscillator (HIRC).<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                     |
| [18]    | OE          | <b>PLL OE (FOUT Enable) Pin Control (Write Protect)</b><br>0 = PLL FOUT Enabled.<br>1 = PLL FOUT is fixed low.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                       |
| [17]    | BP          | <b>PLL Bypass Control (Write Protect)</b><br>0 = PLL is in normal mode (default).<br>1 = PLL clock output is same as PLL input clock FIN.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                            |
| [16]    | PD          | <b>Power-down Mode (Write Protect)</b><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><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                |
| [15:14] | <b>OUTDIV</b> | <b>PLL Output Divider Control (Write Protect)</b><br>Refer to the formulas below the table.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.   |
| [13:9]  | <b>INDIV</b>  | <b>PLL Input Divider Control (Write Protect)</b><br>Refer to the formulas below the table.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.    |
| [8:0]   | <b>FBDIV</b>  | <b>PLL Feedback Divider Control (Write Protect)</b><br>Refer to the formulas below the table.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |

Output Clock Frequency formula:

$$FREF = FIN \times \frac{1}{NR}$$

$$FVCO = FIN \times \frac{2 * NF}{NR}$$

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

where FREF is the comparison frequency for the PFD (phase frequency detector).

For proper operation in normal mode, the following constraints must be satisfied:

$$4 \text{ MHz} \leq FREF \leq 8 \text{ MHz}$$

$$200 \text{ MHz} \leq FVCO \leq 500 \text{ MHz}$$

$$50 \text{ MHz} \leq FOOUT \leq 500 \text{ MHz}$$

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

Table 6.3-1 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+0x50 | 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 | Reserved |    | HIRCSTB | LIRCSTB | PLLSTB | LXTSTB | HXTSTB |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                    |
| [7]    | CLKSFAIL    | <b>Clock Switching Fail Flag (Read Only)</b><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.<br>0 = Clock switching success.<br>1 = Clock switching failure.<br><b>Note:</b> Write 1 to clear the bit to 0. |
| [6:5]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                    |
| [4]    | HIRCSTB     | <b>HIRC Clock Source Stable Flag (Read Only)</b><br>0 = 12 MHz internal high speed RC oscillator (HIRC) clock is not stable or disabled.<br>1 = 12 MHz internal high speed RC oscillator (HIRC) clock is stable and enabled.                                                                                                                                 |
| [3]    | LIRCSTB     | <b>LIRC Clock Source Stable Flag (Read Only)</b><br>0 = 10 kHz internal low speed RC oscillator (LIRC) clock is not stable or disabled.<br>1 = 10 kHz internal low speed RC oscillator (LIRC) clock is stable and enabled.                                                                                                                                   |
| [2]    | PLLSTB      | <b>Internal PLL Clock Source Stable Flag (Read Only)</b><br>0 = Internal PLL clock is not stable or disabled.<br>1 = Internal PLL clock is stable and enabled.                                                                                                                                                                                               |
| [1]    | LXTSTB      | <b>LXT Clock Source Stable Flag (Read Only)</b><br>0 = 32.768 kHz external low speed crystal oscillator (LXT) clock is not stable or disabled.<br>1 = 32.768 kHz external low speed crystal oscillator (LXT) clock is stabled and enabled.                                                                                                                   |
| [0]    | HXTSTB      | <b>HXT Clock Source Stable Flag (Read Only)</b><br>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock is not stable or disabled.<br>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock is stable and enabled.                                                                                                                      |

**Clock Output Control Register (CLK\_CLKOCTL)**

| Register    | Offset      | R/W | Description                   |  |  |  | Reset Value |
|-------------|-------------|-----|-------------------------------|--|--|--|-------------|
| CLK_CLKOCTL | CLK_BA+0x60 | R/W | Clock Output Control Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                           |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                 |
| [6]    | CLK1HZEN    | <b>Clock Output 1Hz Enable Bit</b><br>0 = 1 Hz clock output for 32.768 kHz frequency compensation Disabled.<br>1 = 1 Hz clock output for 32.768 kHz frequency compensation Enabled.                                                                       |
| [5]    | DIV1EN      | <b>Clock Output Divide One Enable Bit</b><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      | <b>Clock Output Enable Bit</b><br>0 = Clock Output function Disabled.<br>1 = Clock Output function Enabled.                                                                                                                                               |
| [3:0]  | FREQSEL     | <b>Clock Output Frequency Selection</b><br>The formula of output frequency is<br>$F_{out} = F_{in}/2^{(N+1)}$ .<br>$F_{in}$ is the input clock frequency.<br>$F_{out}$ is the frequency of divider output clock.<br>N is the 4-bit value of FREQSEL[3:0]. |

Clock Fail Detector Control Register (CLK\_CLKDCTL)

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

|          |    |         |         |          |    |          |          |
|----------|----|---------|---------|----------|----|----------|----------|
| 31       | 30 | 29      | 28      | 27       | 26 | 25       | 24       |
| 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    | <b>HXT Clock Frequency Range Detector Interrupt Enable Bit</b><br>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency range detector fail interrupt Disabled.<br>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency range detector fail interrupt Enabled. |
| [16]    | HXTFQDEN    | <b>HXT Clock Frequency Range Detector Enable Bit</b><br>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency range detector Disabled.<br>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency range detector Enabled.                                         |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |
| [13]    | LXTFIEN     | <b>LXT Clock Fail Interrupt Enable Bit</b><br>0 = 32.768 kHz external low speed crystal oscillator (LXT) clock fail interrupt Disabled.<br>1 = 32.768 kHz external low speed crystal oscillator (LXT) clock fail interrupt Enabled.                                                                     |
| [12]    | LXTFDEN     | <b>LXT Clock Fail Detector Enable Bit</b><br>0 = 32.768 kHz external low speed crystal oscillator (LXT) clock fail detector Disabled.<br>1 = 32.768 kHz external low speed crystal oscillator (LXT) clock fail detector Enabled.                                                                        |
| [11:6]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |
| [5]     | HXTFIEN     | <b>HXT Clock Fail Interrupt Enable Bit</b><br>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock fail interrupt Disabled.<br>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock fail interrupt Enabled.                                                                       |
| [4]     | HXTFDEN     | <b>HXT Clock Fail Detector Enable Bit</b><br>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock fail detector Disabled.<br>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock fail detector Enabled.                                                                          |
| [3:0]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |

**Clock Fail Detector Status Register (CLK\_CLKDSTS)**

| Register   | Offset      | R/W | Description                         | Reset Value |
|------------|-------------|-----|-------------------------------------|-------------|
| CLK_CLKDST | CLK_BA+0x74 | R/W | Clock Fail Detector Status Register | 0x0000_0000 |

|          |    |    |    |    |    |        |        |
|----------|----|----|----|----|----|--------|--------|
| 31       | 30 | 29 | 28 | 27 | 26 | 25     | 24     |
| Reserved |    |    |    |    |    |        |        |
| 23       | 22 | 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 |    |    |    |    |    | LXTFIF | HXTFIF |

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                             |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                   |
| [9:0]   | UPERBD      | <p><b>HXT Clock Frequency Range Detector Upper Boundary Value</b></p> <p>The bits define the maximum value of frequency range detector window.</p> <p>When HXT frequency higher than this maximum frequency value, the HXT Clock Frequency Range Detector Interrupt Flag will set to 1.</p> |

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

| Bits    | Description |                                                                                                                                                                                                                                                                             |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                   |
| [9:0]   | LOWERBD     | <b>HXT Clock Frequency Range Detector Lower Boundary Value</b><br>The bits define the minimum value of frequency range detector window.<br>When HXT frequency lower than this minimum frequency value, the HXT Clock Frequency Range Detector Interrupt Flag will set to 1. |

**Power Manager Control Register (CLK\_PMUCTL)**

| Register   | Offset      | R/W | Description                    |  |  |  | Reset Value |
|------------|-------------|-----|--------------------------------|--|--|--|-------------|
| CLK_PMUCTL | CLK_BA+0x90 | R/W | Power Manager Control Register |  |  |  | 0x0000_0080 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [23]    | RTCWKEN     | <b>RTC Wake-up Enable Bit (Write Protect)</b><br>This is a protected bit. Please refer to open lock sequence to program it.<br>0 = RTC wake-up disable at Deep Power-down mode or Standby Power-down mode.<br>1 = RTC wake-up enabled at Deep Power-down mode or Standby Power-down mode.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                          |
| [22:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [18]    | ACMPSPWK    | <b>ACMP Standby Power-down Mode Wake-up Enable Bit (Write Protect)</b><br>This is a protected bit. Please refer to open lock sequence to program it.<br>0 = ACMP wake-up disable at Standby Power-down mode.<br>1 = ACMP wake-up enabled at Standby Power-down mode.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                               |
| [17:16] | WKPINEN     | <b>Wake-up Pin Enable Bit (Write Protect)</b><br>This is a protected bit. Please refer to open lock sequence to program it.<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><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [11:9]  | WKTMRIS     | <b>Wake-up Timer Time-out Interval Select (Write Protect)</b><br>This is a protected bit. Please refer to open lock sequence to program it.<br>These bits control wake-up timer time-out interval when chip at DPD/SPD mode.<br>000 = Time-out interval is 128 OSC10K clocks (12.8 ms).<br>001 = Time-out interval is 256 OSC10K clocks (25.6 ms).<br>010 = Time-out interval is 512 OSC10K clocks (51.2 ms).                                                      |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | <p>011 = Time-out interval is 1024 OSC10K clocks (102.4ms).<br/>100 = Time-out interval is 4096 OSC10K clocks (409.6ms).<br/>101 = Time-out interval is 8192 OSC10K clocks (819.2ms).<br/>110 = Time-out interval is 16384 OSC10K clocks (1638.4ms).<br/>111 = Time-out interval is 65536 OSC10K clocks (6553.6ms).<br/><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                               |
| [8]   | <b>WKTMRREN</b> | <p><b>Wake-up Timer Enable Bit (Write Protect)</b><br/>This is a protected bit. Please refer to open lock sequence to program it.<br/>0 = Wake-up timer disable at DPD/SPD mode.<br/>1 = Wake-up timer enabled at DPD/SPD mode.<br/><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                                                                                                                   |
| [7:3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [2:0] | <b>PDMSEL</b>   | <p><b>Power-down Mode Selection (Write Protect)</b><br/>This is a protected bit. 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. (NPD)<br/>001 = Low leakage Power-down mode is selected (LLPD).<br/>010 = Fast wake-up Power-down mode is selected (FWPD).<br/>011 = Reserved.<br/>100 = Standby Power-down mode 0 is selected (SPD0) (SRAM retention).<br/>101 = Standby Power-down mode 1 is selected (SPD1).<br/>110 = Deep Power-down mode is selected (DPD).<br/>111 = Reserved.<br/><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |

**Power Manager Status Register (CLK\_PMUSTS)**

| Register   | Offset      | R/W | Description                   |  |  |  | Reset Value |
|------------|-------------|-----|-------------------------------|--|--|--|-------------|
| CLK_PMUSTS | CLK_BA+0x94 | R/W | Power Manager Status Register |  |  |  | 0x0000_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 | ACMPWK   | BODWK | LVRWK | GPDWK | GPCWK | GPBWK | GPAWK |
| 7        | 6        | 5     | 4     | 3     | 2     | 1     | 0     |
| Reserved |          |       |       |       | RTCWK | TMRWK | PINWK |

| Bits    | Description |                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | CLRWK       | <b>Clear Wake-up Flag</b><br>0 = No clear.<br>1= Clear all wake-up flag.                                                                                                                                                  |
| [30:15] | Reserved    | Reserved.                                                                                                                                                                                                                 |
| [14]    | ACMPWK      | <b>ACMP Wake-up Flag (Read Only)</b><br>This flag indicates that wakeup of device from Standby Power-down mode (SPD) was requested with a ACMP transition. This flag is cleared when SPD mode is entered.                 |
| [13]    | BODWK       | <b>BOD Wake-up Flag (Read Only)</b><br>This flag indicates that wakeup of device from Standby Power-down mode (SPD) was requested with a BOD happened. This flag is cleared when SPD mode is entered.                     |
| [12]    | LVRWK       | <b>LVR Wake-up Flag (Read Only)</b><br>This flag indicates that wakeup of device from Standby Power-down mode was requested with a LVR happened. This flag is cleared when SPD mode is entered.                           |
| [11]    | GPDWK       | <b>GPD Wake-up Flag (Read Only)</b><br>This flag indicates that wake-up of chip from Standby Power-down mode was requested by a transition of selected one GPD group pins. This flag is cleared when SPD mode is entered. |
| [10]    | GPCWK       | <b>GPC Wake-up Flag (Read Only)</b><br>This flag indicates that wake-up of chip from Standby Power-down mode was requested by a transition of selected one GPC group pins. This flag is cleared when SPD mode is entered. |
| [9]     | GPBWK       | <b>GPB Wake-up Flag (Read Only)</b><br>This flag indicates that wake-up of chip from Standby Power-down mode was requested by a transition of selected one GPB group pins. This flag is cleared when SPD mode is entered. |
| [8]     | GPAWK       | <b>GPA Wake-up Flag (Read Only)</b><br>This flag indicates that wake-up of chip from Standby Power-down mode was requested by a transition of selected one GPA group pins. This flag is cleared when SPD mode is entered. |

|       |                 |                                                                                                                                                                                                                                                  |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                        |
| [2]   | <b>RTCWK</b>    | <b>RTC Wake-up Flag (Read Only)</b><br>This flag indicates that wakeup of device from Standby Power-down (SPD) mode was requested with a RTC alarm, tick time or tamper happened. This flag is cleared when SPD mode is entered.                 |
| [1]   | <b>TMRWK</b>    | <b>Timer Wake-up Flag (Read Only)</b><br>This flag indicates that wake-up of chip from Deep Power-down mode (DPD) or Standby Power-down (SPD) mode was requested by wakeup timer time-out. This flag is cleared when DPD or SPD mode is entered. |
| [0]   | <b>PINWK</b>    | <b>Pin Wake-up Flag (Read Only)</b><br>This flag indicates that wake-up of chip from Deep Power-down mode was requested by a transition of the WAKEUP pin (GPC.0). This flag is cleared when DPD mode is entered.                                |

LDO Control Register (CLK\_LDOCTL)

| Register   | Offset      | R/W | Description          |  |  |  | Reset Value |
|------------|-------------|-----|----------------------|--|--|--|-------------|
| CLK_LDOCTL | CLK_BA+0x98 | R/W | LDO Control Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | <b>Reserved</b> | Reserved.                                                                                                                                                      |
| [18]    | <b>PDBIASEN</b> | <b>Power-down Bias Enable Bit</b><br>0 = Reserved.<br>1 = Power-down bias Enabled.<br><b>Note:</b> This bit should set to 1 before chip enter power-down mode. |
| [17:0]  | <b>Reserved</b> | Reserved.                                                                                                                                                      |

**Standby Power-down Wake-up De-bounce Control Register (CLK\_SWKDBCTL)**

| Register     | Offset      | R/W | Description                                           |  |  |  |  | Reset Value |
|--------------|-------------|-----|-------------------------------------------------------|--|--|--|--|-------------|
| CLK_SWKDBCTL | CLK_BA+0x9C | R/W | Standby Power-down Wake-up De-bounce 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 |    |    |    | SWKDBCLKSEL |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [3:0]  | SWKDBCLKSEL | <p><b>Standby Power-down Wake-up De-bounce Sampling Cycle Selection</b></p> <p>0000 = Sample wake-up input once per 1 clocks.<br/>     0001 = Sample wake-up input once per 2 clocks.<br/>     0010 = Sample wake-up input once per 4 clocks.<br/>     0011 = Sample wake-up input once per 8 clocks.<br/>     0100 = Sample wake-up input once per 16 clocks.<br/>     0101 = Sample wake-up input once per 32 clocks.<br/>     0110 = Sample wake-up input once per 64 clocks.<br/>     0111 = Sample wake-up input once per 128 clocks.<br/> <br/>     1000 = Sample wake-up input once per 256 clocks.<br/>     1001 = Sample wake-up input once per 2*256 clocks.<br/>     1010 = Sample wake-up input once per 4*256 clocks.<br/>     1011 = Sample wake-up input once per 8*256 clocks.<br/>     1100 = Sample wake-up input once per 16*256 clocks.<br/>     1101 = Sample wake-up input once per 32*256 clocks.<br/>     1110 = Sample wake-up input once per 64*256 clocks..<br/>     1111 = Sample wake-up input once per 128*256 clocks..</p> <p><b>Note:</b> De-bounce counter clock source is the 10 kHz internal low speed RC oscillator (LIRC).</p> |

GPA Standby Power-down Wake-up Control Register (CLK\_PASWKCTL)

| Register         | Offset      | R/W | Description                                     |  |  |  |  | Reset Value |
|------------------|-------------|-----|-------------------------------------------------|--|--|--|--|-------------|
| CLK_PASWK<br>CTL | CLK_BA+0xA0 | R/W | GPA Standby Power-down 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 |    |    |    |          |        |        |      | DBEN |
| 7        | 6  | 5  | 4  | 3        | 2      | 1      | 0    |      |
| WKPSEL   |    |    |    | Reserved | PFWKEN | PRWKEN | WKEN |      |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [8]    | DBEN        | <p><b>GPA Input Signal De-bounce Enable Bit</b></p> <p>The DBEN bit is used to enable the de-bounce function for each corresponding IO. If the input signal pulse width cannot be sampled by continuous two de-bounce sample cycle, the input signal transition is seen as the signal bounce and will not trigger the wake-up. The de-bounce clock source is the 10 kHz internal low speed RC oscillator.</p> <p>0 = Standby power-down wake-up pin De-bounce function Disabled.<br/>1 = Standby power-down wake-up pin De-bounce function Enabled.</p> <p>The de-bounce function is valid only for edge triggered.</p>                                                                                                                                                          |
| [7:4]  | WKPSEL      | <p><b>GPA Standby Power-down Wake-up Pin Select</b></p> <p>0000 = GPA.0 wake-up function Enabled.<br/>0001 = GPA.1 wake-up function Enabled.<br/>0010 = GPA.2 wake-up function Enabled.<br/>0011 = GPA.3 wake-up function Enabled.<br/>0100 = GPA.4 wake-up function Enabled.<br/>0101 = GPA.5 wake-up function Enabled.<br/>0110 = GPA.6 wake-up function Enabled.<br/>0111 = GPA.7 wake-up function Enabled.<br/>1000 = GPA.8 wake-up function Enabled.<br/>1001 = GPA.9 wake-up function Enabled.<br/>1010 = GPA.10 wake-up function Enabled.<br/>1011 = GPA.11 wake-up function Enabled.<br/>1100 = GPA.12 wake-up function Enabled.<br/>1101 = GPA.13 wake-up function Enabled.<br/>1110 = GPA.14 wake-up function Enabled.<br/>1111 = GPA.15 wake-up function Enabled.</p> |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|     |               |                                                                                                                                                                     |
|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>PFWKEN</b> | <b>Pin Falling Edge Wake-up Enable Bit</b><br>0 = GPA group pin falling edge wake-up function Disabled.<br>1 = GPA group pin falling edge wake-up function Enabled. |
| [1] | <b>PRWKEN</b> | <b>Pin Rising Edge Wake-up Enable Bit</b><br>0 = GPA group pin rising edge wake-up function Disabled.<br>1 = GPA group pin rising edge wake-up function Enabled.    |
| [0] | <b>WKEN</b>   | <b>Standby Power-down Pin Wake-up Enable Bit</b><br>0 = GPA group pin wake-up function Disabled.<br>1 = GPA group pin wake-up function Enabled.                     |

GPB Standby Power-down Wake-up Control Register (CLK\_PBSWKCTL)

| Register         | Offset      | R/W | Description                                     |  |  |  |  | Reset Value |
|------------------|-------------|-----|-------------------------------------------------|--|--|--|--|-------------|
| CLK_PBSWK<br>CTL | CLK_BA+0xA4 | R/W | GPB Standby Power-down 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 |    |    |    |          |        |        |      | DBEN |
| 7        | 6  | 5  | 4  | 3        | 2      | 1      | 0    |      |
| WKPSEL   |    |    |    | Reserved | PFWKEN | PRWKEN | WKEN |      |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [8]    | DBEN        | <p><b>GPB Input Signal De-bounce Enable Bit</b></p> <p>The DBEN bit is used to enable the de-bounce function for each corresponding IO. If the input signal pulse width cannot be sampled by continuous two de-bounce sample cycle, the input signal transition is seen as the signal bounce and will not trigger the wake-up. The de-bounce clock source is the 10 kHz internal low speed RC oscillator.</p> <p>0 = Standby power-down wake-up pin De-bounce function Disabled.<br/>1 = Standby power-down wake-up pin De-bounce function Enabled.</p> <p>The de-bounce function is valid only for edge triggered.</p>                                                                                                                                                          |
| [7:4]  | WKPSEL      | <p><b>GPB Standby Power-down Wake-up Pin Select</b></p> <p>0000 = GPB.0 wake-up function Enabled.<br/>0001 = GPB.1 wake-up function Enabled.<br/>0010 = GPB.2 wake-up function Enabled.<br/>0011 = GPB.3 wake-up function Enabled.<br/>0100 = GPB.4 wake-up function Enabled.<br/>0101 = GPB.5 wake-up function Enabled.<br/>0110 = GPB.6 wake-up function Enabled.<br/>0111 = GPB.7 wake-up function Enabled.<br/>1000 = GPB.8 wake-up function Enabled.<br/>1001 = GPB.9 wake-up function Enabled.<br/>1010 = GPB.10 wake-up function Enabled.<br/>1011 = GPB.11 wake-up function Enabled.<br/>1100 = GPB.12 wake-up function Enabled.<br/>1101 = GPB.13 wake-up function Enabled.<br/>1110 = GPB.14 wake-up function Enabled.<br/>1111 = GPB.15 wake-up function Enabled.</p> |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|     |               |                                                                                                                                                                     |
|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>PFWKEN</b> | <b>Pin Falling Edge Wake-up Enable Bit</b><br>0 = GPB group pin falling edge wake-up function Disabled.<br>1 = GPB group pin falling edge wake-up function Enabled. |
| [1] | <b>PRWKEN</b> | <b>Pin Rising Edge Wake-up Enable Bit</b><br>0 = GPB group pin rising edge wake-up function Disabled.<br>1 = GPB group pin rising edge wake-up function Enabled.    |
| [0] | <b>WKEN</b>   | <b>Standby Power-down Pin Wake-up Enable Bit</b><br>0 = GPB group pin wake-up function Disabled.<br>1 = GPB group pin wake-up function Enabled.                     |

GPC Standby Power-down Wake-up Control Register (CLK\_PCSWKCTL)

| Register     | Offset      | R/W | Description                                     |  |  |  |  | Reset Value |
|--------------|-------------|-----|-------------------------------------------------|--|--|--|--|-------------|
| CLK_PCSWKCTL | CLK_BA+0xA8 | R/W | GPC Standby Power-down 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 |    |    |    |          |        |        |      | DBEN |
| 7        | 6  | 5  | 4  | 3        | 2      | 1      | 0    |      |
| WKPSEL   |    |    |    | Reserved | PFWKEN | PRWKEN | WKEN |      |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [8]    | DBEN        | <p><b>GPC Input Signal De-bounce Enable Bit</b></p> <p>The DBEN bit is used to enable the de-bounce function for each corresponding IO. If the input signal pulse width cannot be sampled by continuous two de-bounce sample cycle, the input signal transition is seen as the signal bounce and will not trigger the wake-up. The de-bounce clock source is the 10 kHz internal low speed RC oscillator.</p> <p>0 = Standby power-down wake-up pin De-bounce function Disabled.<br/>1 = Standby power-down wake-up pin De-bounce function Enabled.</p> <p><b>Note:</b> The de-bounce function is valid only for edge triggered.</p>                                                                                                                                             |
| [7:4]  | WKPSEL      | <p><b>GPC Standby Power-down Wake-up Pin Select</b></p> <p>0000 = GPC.0 wake-up function Enabled.<br/>0001 = GPC.1 wake-up function Enabled.<br/>0010 = GPC.2 wake-up function Enabled.<br/>0011 = GPC.3 wake-up function Enabled.<br/>0100 = GPC.4 wake-up function Enabled.<br/>0101 = GPC.5 wake-up function Enabled.<br/>0110 = GPC.6 wake-up function Enabled.<br/>0111 = GPC.7 wake-up function Enabled.<br/>1000 = GPC.8 wake-up function Enabled.<br/>1001 = GPC.9 wake-up function Enabled.<br/>1010 = GPC.10 wake-up function Enabled.<br/>1011 = GPC.11 wake-up function Enabled.<br/>1100 = GPC.12 wake-up function Enabled.<br/>1101 = GPC.13 wake-up function Enabled.<br/>1110 = GPC.14 wake-up function Enabled.<br/>1111 = GPC.15 wake-up function Enabled.</p> |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|     |               |                                                                                                                                                                     |
|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>PFWKEN</b> | <b>Pin Falling Edge Wake-up Enable Bit</b><br>0 = GPC group pin falling edge wake-up function Disabled.<br>1 = GPC group pin falling edge wake-up function Enabled. |
| [1] | <b>PRWKEN</b> | <b>Pin Rising Edge Wake-up Enable Bit</b><br>0 = GPC group pin rising edge wake-up function Disabled.<br>1 = GPC group pin rising edge wake-up function Enabled.    |
| [0] | <b>WKEN</b>   | <b>Standby Power-down Pin Wake-up Enable Bit</b><br>0 = GPC group pin wake-up function Disabled.<br>1 = GPC group pin wake-up function Enabled.                     |

GPD Standby Power-down Wake-up Control Register (CLK\_PDSWKCTL)

| Register     | Offset      | R/W | Description                                     |  |  |  |  | Reset Value |
|--------------|-------------|-----|-------------------------------------------------|--|--|--|--|-------------|
| CLK_PDSWKCTL | CLK_BA+0xAC | R/W | GPD Standby Power-down 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 |    |    |    |          |        |        |      | DBEN |
| 7        | 6  | 5  | 4  | 3        | 2      | 1      | 0    |      |
| WKPSEL   |    |    |    | Reserved | PFWKEN | PRWKEN | WKEN |      |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [8]    | DBEN        | <p><b>GPD Input Signal De-bounce Enable Bit</b></p> <p>The DBEN bit is used to enable the de-bounce function for each corresponding IO. If the input signal pulse width cannot be sampled by continuous two de-bounce sample cycle, the input signal transition is seen as the signal bounce and will not trigger the wake-up. The de-bounce clock source is the 10 kHz internal low speed RC oscillator.</p> <p>0 = Standby power-down wake-up pin De-bounce function Disabled.<br/>1 = Standby power-down wake-up pin De-bounce function Enabled.</p> <p><b>Note:</b> The de-bounce function is valid only for edge triggered.</p>                                                                                                                                             |
| [7:4]  | WKPSEL      | <p><b>GPD Standby Power-down Wake-up Pin Select</b></p> <p>0000 = GPD.0 wake-up function Enabled.<br/>0001 = GPD.1 wake-up function Enabled.<br/>0010 = GPD.2 wake-up function Enabled.<br/>0011 = GPD.3 wake-up function Enabled.<br/>0100 = GPD.4 wake-up function Enabled.<br/>0101 = GPD.5 wake-up function Enabled.<br/>0110 = GPD.6 wake-up function Enabled.<br/>0111 = GPD.7 wake-up function Enabled.<br/>1000 = GPD.8 wake-up function Enabled.<br/>1001 = GPD.9 wake-up function Enabled.<br/>1010 = GPD.10 wake-up function Enabled.<br/>1011 = GPD.11 wake-up function Enabled.<br/>1100 = GPD.12 wake-up function Enabled.<br/>1101 = GPD.13 wake-up function Enabled.<br/>1110 = GPD.14 wake-up function Enabled.<br/>1111 = GPD.15 wake-up function Enabled.</p> |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|     |               |                                                                                                                                                                     |
|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>PFWKEN</b> | <b>Pin Falling Edge Wake-up Enable Bit</b><br>0 = GPD group pin falling edge wake-up function Disabled.<br>1 = GPD group pin falling edge wake-up function Enabled. |
| [1] | <b>PRWKEN</b> | <b>Pin Rising Edge Wake-up Enable Bit</b><br>0 = GPD group pin rising edge wake-up function Disabled.<br>1 = GPD group pin rising edge wake-up function Enabled.    |
| [0] | <b>WKEN</b>   | <b>Standby Power-down Pin Wake-up Enable Bit</b><br>0 = GPD group pin wake-up function Disabled.<br>1 = GPD group pin wake-up function Enabled.                     |

GPIO Standby Power-down Control Register (CLK\_IOPDCTL)

| Register    | Offset      | R/W | Description                              | Reset Value |
|-------------|-------------|-----|------------------------------------------|-------------|
| CLK_IOPDCTL | CLK_BA+0xB0 | R/W | GPIO Standby Power-down 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 |    |    |    |    |    |    | IOHR |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                        |
| [0]    | IOHR        | <p><b>GPIO Hold Release</b></p> <p>When GPIO enters standby power-down mode, all I/O status are hold to keep normal operating status. After chip was waked up from standby power-down mode, the I/O are still keep hold status until user set this bit to release I/O hold status.</p> <p><b>Note:</b> This bit is auto cleared by hardware.</p> |

## 6.4 Flash Memory Controller (FMC)

### 6.4.1 Overview

The FMC is equipped with dual-bank on-chip embedded Flash (BANK0 and BANK1) for application and configurable Data Flash to store some application dependent data. Both BANK0 and BANK1 have 64/128/256 Kbytes space. Thus, the total size of application rom (APROM) is 128K/256K/512K. A User Configuration block provides for system initiation in BANK0. A 4 Kbytes loader ROM (LDROM) is used for In-System-Programming (ISP) function in BANK0. A 4 Kbytes security protection ROM (SPROM) can conceal user program. A 2 Kbytes one-time-program ROM (OTP) is used for recording one-time-program data in BANK1. A 32K Boot Loader consists of native ISP functions. A 4KB cache with zero wait cycle is used to improve Flash access performance. This chip also supports In-Application-Programming (IAP) function. User switches the code executing without chip reset after the embedded Flash is updated.

### 6.4.2 Features

- Supports dual-bank Flash macro for safe firmware upgrade
- Supports 128/256/512 Kbytes application ROM (APROM)
- Supports 4 Kbytes loader ROM (LDROM)
- Supports 4 Kbytes security protection ROM (SPROM) to conceal user program
- Supports mirror SPROM in dual-bank Flash macro to read SPROM code while writing other ROM
- Supports Data Flash with configurable memory size
- Supports 16 bytes User Configuration block to control system initiation
- Supports 2 Kbytes one-time-program ROM (OTP)
- Supports 4 Kbytes page erase for all embedded Flash
- Supports Boot Loader with native In-System-Programming (ISP) functions
- Supports Secure Boot function for code integrity and authenticity
- Supports Security Key protection function for APROM, LDROM, SPROM, User Configuration block and KPROM protection
- Supports 32-bit/64-bit and multi-word Flash programming function
- Supports fast Flash programming verification function
- Supports CRC32 checksum calculation function
- Supports Flash all one verification function
- Supports In-System-Programming (ISP) / In-Application-Programming (IAP) to update embedded Flash memory
- Supports cache memory to improve Flash access performance and reduce power consumption

### 6.4.3 Block Diagram

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



Figure 6.4-1 Flash Memory Controller Block Diagram

### AHB Slave Interface

There are two AHB slave interfaces in Flash memory controller, one is from both Cortex®-M4 I-Bus and D-Bus for the instruction and data fetch; the other is from Cortex®-M4 S-Bus for Flash control registers access including ISP registers.

### Cache Memory Controller

A 4 KB cache with zero wait cycle is implemented between Cortex®-M4 CPU and embedded Flash memory. This cache memory controller improves the Flash access performance and reduces power consumption of the embedded Flash memory.

### **Boot Loader**

The Boot Loader is 32KB, and consists of native ISP functions to update embedded Flash memory. The Boot Loader content is read only, but not programmable.

### **Flash Control Registers**

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

### **Flash Initialization Controller**

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

### **Flash Operation Controller**

The Flash operations, such as Flash erase, Flash program, and Flash read operation, have specific control timing for embedded Flash memory. The Flash operation controller generates those control timing 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 consists of the user configuration block, 4KB LDROM, two 4KB SPROM, 2KB OTP, 8KB KPROM and 128KB/256KB/512KB APROM with Data Flash. The page erase Flash size is 4KB, and minimum program bit size is 32 bits.

#### 6.4.4 Functional Description

FMC functions include the memory organization, boot selection, secure boot, 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 dual-bank embedded Flash memory and boot loader. The dual-bank embedded Flash memory is programmable, and includes APROM, LDROM, SPROM, Data Flash, the User Configuration block, OTP and KPROM. Boot Loader is a Mask ROM with ISP boot codes to support firmware download, boot control, security control and firmware execution. The address map includes Flash memory map and five system address maps: LDROM with IAP, LDROM without IAP, APROM with IAP, APROM without IAP, and Boot Loader with IAP functions..

| BANK | Flash Memory Block | Address Range         |
|------|--------------------|-----------------------|
| 0    | APROM with 512KB   | 0x00_0000 ~ 0x03_ffff |
|      | APROM with 256KB   | 0x00_0000 ~ 0x01_ffff |
|      | APROM with 128KB   | 0x00_0000 ~ 0x00_ffff |
|      | User Configuration | 0x30_0000 ~ 0x30_000f |
|      | LDROM              | 0x10_0000 ~ 0x10_0fff |
|      | SPROM              | 0x20_0000 ~ 0x20_0fff |
| 1    | APROM with 512KB   | 0x04_0000 ~ 0x07_ffff |
|      | APROM with 256KB   | 0x02_0000 ~ 0x03_ffff |
|      | APROM with 128KB   | 0x01_0000 ~ 0x01_ffff |
|      | OTP                | 0x31_0000 ~ 0x31_0bff |
|      | KPROM-KEY          | 0x30_1000 ~ 0x30_11ff |
|      | KPROM - KPCNTROM   | 0x30_1200 ~ 0x30_1fff |

Table 6.4-1 Dual-Bank Block Address Range

##### 6.4.4.2 LDROM APROM and Data Flash

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



Figure 6.4-2 Data Flash Shared with APROM Examples (128/256/512 KB)

#### 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, brown-out voltage level, and Data Flash base address. It works like a fuse for power on setting. It is loaded from Flash memory to its corresponding control registers during chip power on. User can set these bits according to different application requests. User Configuration block can be updated by ISP function and located at 0x0030\_0000 with four 32 bits words (CONFIG0, CONFIG1, CONFIG2 and CONFIG3). Any change on User Configuration block will take effect after system reboot.

**CONFIG0 (Address = 0x0030\_0000)**

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

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | CWDTEN[2]    | <p><b>Watchdog Timer Hardware Enable Bit</b><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 can't be disabled.</p> <p><b>CWDTEN[2:0]</b> is CONFIG0[31][4][3],</p> <p>011 = WDT hardware enable function is active. WDT clock is always on except chip enters Power-down mode. When chip enter 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.</p> <p>111 = WDT hardware enable function is inactive.</p> <p>Others = WDT hardware enable function is active. WDT clock is always on.</p> |
| [30]    | CWDTPDEN     | <p><b>Watchdog Clock Power-down Enable Bit</b><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.</p> <p><b>Note:</b> This bit only works if CWDTEN[2:0] is set to 011</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [29:28] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [27]    | CFGXT1       | <p><b>HXT Mode selection</b><br/> 0 = HXT work as external clock mode. PF.3 is configured as external clock input pin.<br/> 1 = HXT work as crystal mode. PF.2 and PF.3 are configured as external high speed crystal (HXT) pins.</p> <p><b>Note:</b> When CFGXT1 = 0, PF.3 MFP should be setting as GPIO mode. The DC characteristic of XT1_IN is the same as GPIO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [25:24] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [23:21] | CBOV         | <p><b>Brown-Out Voltage Selection</b><br/> 000 = Brown-out voltage is 1.6V.<br/> 001 = Brown-out voltage is 1.8V.<br/> 010 = Brown-out voltage is 2.0V.<br/> 011 = Brown-out voltage is 2.2V.<br/> 100 = Brown-out voltage is 2.4V.<br/> 101 = Brown-out voltage is 2.6V.<br/> 110 = Brown-out voltage is 2.8V.<br/> 111 = Brown-out voltage is 3.0V.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [20]    | <b>CBORST</b>   | <b>Brown-Out Reset Enable Bit</b><br>0 = Brown-out reset Enabled after powered on.<br>1 = Brown-out reset Disabled after powered on.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [19]    | <b>CBODEN</b>   | <b>Brown-Out Detector Enable Bit</b><br>0= Brown-out detect Enabled after powered on.<br>1= Brown-out detect Disabled after powered on.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [18:13] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [12]    | <b>SPLCAEN</b>  | <b>SPROM Lock Cacheable Enable Bit</b><br>0 =The content of SPROM is not cacheable.<br>1 = The content of SPROM is cacheable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [11]    | <b>ICELOCK</b>  | <b>ICE Lock Bit</b><br>This bit only used to disable ICE function. User may use it with LOCK (CONFIG0[1]) bit or ALOCK (CONFIG2[7:0]) bits to increase security level.<br>0 = ICE function Disabled.<br>1 = ICE function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [10]    | <b>CIOINI</b>   | <b>I/O Initial State Selection</b><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]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [7:6]   | <b>CBS</b>      | <b>Chip Booting Selection</b><br>When CBS[0] = 0, the LDROM base address is mapping to 0x100000 and APROM base address is mapping to 0x0. User could access both APROM and LDROM without boot switching. In other words, if IAP mode is supported, the code in LDROM and APROM can be called by each other.<br>CBS[0] value will be assigned to 0 when MBS =0.<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><b>Note:</b><br>BS (FMC_ISPCTL[ 1]) is only be used to control boot switching when CBS[0] = 1 and MBS = 1.<br>VECMAP (FMC_ISPSTS[23:9]) is only be used to remap 0x0~0x1ff when CBS[0] = 0 or MBS = 0. |
| [5]     | <b>MBS</b>      | <b>Boot Loader Booting Selection</b><br>0 = Booting from Boot Loader, and ignored CBS setting.<br>1 = Booting from APROM or LDROM, depended on CBS value.<br><b>Note:</b><br>BS (FMC_ISPCTL[1]) is only be used to control boot switching when CBS[0] = 1 and MBS = 1.<br>VECMAP (FMC_ISPSTS[23:9]) is only be used to remap 0x0~0x1ff when CBS[0] = 0 or MBS = 0.                                                                                                                                                                                                                                                                                                                                                                         |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4:3] | <b>CWDTEN</b>   | <b>Watchdog Timer Hardware Enable Bit</b><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 can't be disable.<br><b>CWDTEN[2:0]</b> is CONFIG0[31][4][3],<br>011 = WDT hardware enable function is active. WDT clock is always on except chip enter Power-down mode. When chip enter 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.<br>Others = WDT hardware enable function is active. WDT clock is always on. |
| [2]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [1]   | <b>LOCK</b>     | <b>Security Lock Control</b><br>0 = Flash memory content is locked.<br>1 = Flash memory content is not locked if ALOCK(CONFIG2[7:0]) is 0x5A.<br>When Flash data is locked key LOCK,user can look the lock effect of FMC up in lock effect tables.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [0]   | <b>DFEN</b>     | <b>Data Flash Enable Bit</b><br>The Data Flash is shared with APROM, and the base address of Data Flash is decided by DFBA (CONFIG1[19:0]) when DFEN is 0.<br>0 = Data Flash Enabled.<br>1 = Data Flash Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Note:** The config bits should be 1 if reserved.

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

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

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

**Note:** The config bits should be 1 if reserved.

**CONFIG2 (Address = 0x0030\_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  |
| SBLOCK   |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| ALOCK    |    |    |    |    |    |    |    |

| Bits    | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [15:8]  | SBLOCK       | <p><b>Secure Boot Lock Control</b></p> <p>0x5A = Secure boot function is disable and Flash memory content is unlocked if LOCK (CONFIG0[1]) is 1 and ALOCK (CONFIG2[7:0]) is 0x5A</p> <p>The others = Secure boot function is enable and LOCK/ALOCK is also locked.</p> <p>When Secure boot function is enable, FMC will boot from Boot Loader with IAP mode (i.e., CBS[0] value in CONFIG0 will be assigned to 0) and then perform secure boot mechanism.</p> <p>When SBLOCK ≠ 0x5A with ICE, only Chip Erase ISP command can be performed via ICE.</p> <p>When Flash data is locked by SBLOCK, user must look the lock effect of FMC up in lock effect tables.</p> |
| [7:0]   | ALOCK        | <p><b>Advance Security Lock Control</b></p> <p>0x5A = Flash memory content is unlocked if LOCK (CONFIG0[1]) is 1.</p> <p>The others = Flash memory content is locked.</p> <p>When Flash data is locked by ALOCK, user must look the lock effect of FMC up in lock effect tables.</p>                                                                                                                                                                                                                                                                                                                                                                                |

**Note:** The config bits should be 1 if reserved.

**CONFIG3 (Address = 0x0030\_000C)**

|          |         |    |          |    |          |    |    |
|----------|---------|----|----------|----|----------|----|----|
| 31       | 30      | 29 | 28       | 27 | 26       | 25 | 24 |
| Reserved |         |    |          |    |          |    |    |
| 23       | 22      | 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 | SPIMPSL |    | Reserved |    | UART1PSL |    |    |

| Bits   | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [5:4]  | SPIMPSL      | <p><b>Boot Loader SPIM Multi-function Pin Select</b></p> 00: SPIM_CLK (PA.2), SPIM_SS (PA.3), SPIM_MISO (PA.1), SPIM_MOSI (PA.0)<br>01: SPIM_CLK (PC.2), SPIM_SS (PC.3), SPIM_MISO (PC.1), SPIM_MOSI (PC.0)<br>10: SPIM_CLK (PG.12), SPIM_SS (PG.11), SPIM_MISO (PG.13), SPIM_MOSI (PG.14)<br>11: SPIM_CLK (PE.4), SPIM_SS (PE.5), SPIM_MISO (PE.3), SPIM_MOSI (PE.2)<br>Note: When chip reset, default value comes from CONFIG3[5:4] |
| [3:2]  | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [1:0]  | UART1PSL     | <p><b>Boot Loader UART1 Multi-function Pin Select</b></p> 00: UART1_TXD (PB.3), UART1_RXD (PB.2)<br>01: UART1_TXD (PA.9), UART1_RXD (PA.8)<br>10: UART1_TXD (PA.3), UART1_RXD (PA.2)<br>11: UART1_TXD (PB.7), UART1_RXD (PB.6)<br>Note: When chip reset, default value comes from CONFIG3[1:0]                                                                                                                                        |

**Note:** The config bits should be 1 if reserved.

#### 6.4.4.4 Security Protection Memory (SPROM)

The security protection memory (SPROM) is used to store instructions for security application. The SPROM is 4 Kbytes with location address 0x20\_0000 ~ 0x20\_0FFF. SPROM is only erased by “page erase command”. The last byte of SPROM (address: 0x0020\_0FFF) is used to identify the SPROM code is secured or non-secured as show in Figure 6.4-3. SPROM has three modes, (1) SPROM non-secured mode (the last byte is 0xFF), (2)SPROM debug mode (the last byte is 0xAA), (3) SPROM secured mode (the last byte is not 0xFF or 0xAA).

In order to conceal SPROM code in secured mode, CPU only can perform instruction fetch to SPROM and then get the SPROM data; any CPU data access to SPROM directly without perform instruction fetch to SPROM, CPU will get all one (0xffff\_ffff). When Cortex®-M4 ICE (In-Circuit-Emulator) debugging in SPROM secured code, any ICE breakpoint setting on SPROM program and dumping SPROM secured code out by ICE and PDMA are illegal for security protection issue; but user can debug SPROM program with ICE port connection in SPROM debug mode.

The SPROM secured flag is shown at SCODE (FMC\_ISPSTS[31]), which is cleared after the SPROM page erase operation complete, and set at Flash initiation if the last byte of SPROM is not 0xFF. In addition, users can also set the SCODE by programming 1 in the register FMC\_ISPSTS[31]. Before executing the SPROM page erase operation, SPUEN (FMC\_ISPCTL[2]) must be set to 1 and ISPDAT[31:0] register must be set to 0x0055AA03 in SPROM secured mode.

To implement “safe firmware upgrade”, allocate one SPROM page with the same content of security application in each bank to make sure that the security application can be performed in any bank. When upgrading firmware code and accessing SPROM at the same time, FMC will return the instructions of SPROM in any idle bank. Please note that all SPROM will be erased or programmed automatically when executing ISP CMDs Flash page erase function or Flash data program function on any SPROM.



Figure 6.4-3 SPROM Security Mode

#### 6.4.4.5 One Time Program Memory (OTP)

The One time program memory (OTP) is used to store the important information that are not allowed user to modify them twice. The OTP is 3 Kbytes with location address 0x31\_0000 ~ 0x31\_0BFF. The maximum size of OTP data are 2Kbytes from 0x31\_0000 ~ 0x31\_07FF. Every 64 bits of OTP data has one 32 bits “LOCK BIT” from 0x31\_0800 to 0x31\_0BFF, as shown in Figure 6.4-4.

The purpose of “LOCK BIT” is for recording if the programmed address had been locked (LOCK BIT≠0xFFFF\_FFFF) or not (LOCK BIT= 0xFFFF\_FFFF) in OTP. For examples, when LOCK BIT0 is not “0xFFFFFFFF”, OTP0 cannot be programmed again, regardless its content is all 1 or not. The “Flash page erase /mass erase command/ FLASH 64-bit Program/ FLASH Multi-Word Program” are never allowed to be executed in OTP. Before updating the content of OTP from 0x31\_0000 to 0x31\_07FF, user must check their “LOCK BIT” firstly. After finishing programming OTP data, user must write a non-0xFFFF\_FFFF in the “LOCK BIT” of the above programmed data to make sure that no one can modify them. OTP is only readable by ISP command and un-readable by CPU read directly.



Figure 6.4-4 OTP Memory Map

#### 6.4.4.6 Key Protection Memory (KPROM)

The Key Protection Memory (KPROM) is used to store 96-bit security key content and the entry limitations of key mismatch. KPROM costs 28 bytes at address 0x30\_1000 ~ 0x30\_1017 in the first page and at address 0x30\_1200 ~ 0x30\_1203 in the second page. All above two pages can be programmed or page-erased while KEYLOCK (FMC\_KPKEYSTS [1]) is inactive. KPROM cannot be read directly through ISP/ICE/ICP /Writer interface and commands. If Users want to check the data of KPROM, the only way is verifying the data of security key (KPKEY0ROM, KPKEY1ROM, and KPKEY2ROM) by executing the Key Comparison operation. The memory map of KPROM is shown in Figure 6.4-5.



Figure 6.4-5 KROM Memory Map

**KPKEY0ROM (Address = 0x0030\_1000)**

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

| Bits   | Description |                                                                                                                                                                                                               |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | KPKEY0ROM   | <b>KEY #0 (Write Only)</b><br>KPKEY0ROM is the first 32-bit of Security Key (total 96 bits), it can be erased and programmed while KEYLOCK (FMC_KPKEYSTS [1]) is inactive. KPKEY0ROM cannot be read directly. |

**Note:** The bits of KPKEY0ROM should be 1 if reserved.

KPKEY1ROM (Address = 0x0030\_1004)

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

| Bits   | Description |                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| [31:0] | KPKEY1ROM   | <b>KEY #1 (Write Only)</b><br>KPKEY1ROM is the second 32-bit of Security Key (total 96 bits), it can be erased and programmed while KEYLOCK (FMC_KPKEYSTS [1]) is inactive. KPKEY1ROM cannot be read directly. |  |  |  |  |  |  |  |

KPKEY2ROM (Address = 0x0030\_1008)

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

| Bits   | Description |                                                                                                                                                                                                                          |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | KPKEY2ROM   | <p><b>KEY #2 (Write Only)</b></p> <p>KPKEY2ROM is the third 32-bit of Security Key (total 96 bits), it can be erased and programmed while KEYLOCK (FMC_KPKEYSTS [1]) is inactive, KPKEY2ROM cannot be read directly.</p> |

**KPMAXROM (Address = 0x0030\_100C)**

|          |    |    |    |    |                 |    |    |
|----------|----|----|----|----|-----------------|----|----|
| 31       | 30 | 29 | 28 | 27 | 26              | 25 | 24 |
| Reserved |    |    |    |    |                 |    |    |
| 23       | 22 | 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 |    |    |    |    | <b>KPMAXROM</b> |    |    |

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved        | Reserved.                                                                                                                                                                                                                                                                                                                                                                          |
| [2:0]  | <b>KPMAXROM</b> | <p><b>Power-on Maximum Number of Error Key Entry (Write Only)</b></p> <p>KPMAXROM is used to limit the number of power-on when the security key comparison is unmatched. KPMAXROM will be copied to KPMAX (FMC_KPCNT [10:8]) at power-on or reset cycle. KPMAXROM can be erased and programmed while KEYLOCK (FMC_KPKEYSTS [1]) is inactive. KPMAXROM cannot be read directly.</p> |

**KPKEMAXROM (Address = 0x0030\_1010)**

|          |    |    |                   |    |    |    |    |
|----------|----|----|-------------------|----|----|----|----|
| 31       | 30 | 29 | 28                | 27 | 26 | 25 | 24 |
| Reserved |    |    |                   |    |    |    |    |
| 23       | 22 | 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 |    |    | <b>KPKEMAXROM</b> |    |    |    |    |

| Bits   | Description       |                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved          | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |
| [4:0]  | <b>KPKEMAXROM</b> | <b>Maximum Number of Error Key Entry for Each Power-on (Write Only)</b><br>KPKEMAXROM is used to limit number of KEY-unmatched in KEY comparison operation for each power-on. KPKEMAXROM will be copied to KPKEMAX(FMC_KPKECNT[12:8]) at power-on or reset cycle. KPKEMAXROM can be erased and programmed while KEYLOCK (FMC_KPKEYSTS [1]) is inactive, KPKEMAXROM cannot read directly. |

**KPKEYENROM (Address = 0x0030\_1014)**

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [7:0]  | KPKEYENROM  | <p><b>KEYLOCK Enable Control (Write Only)</b></p> <p>KPKEYENROM is used to enable KEYLOCK (FMC_KPKEYSTS [1]) at power-on or reset cycle. KPKEYENROM can be erased and programmed while KEYLOCK (FMC_KPKEYSTS [1]) is inactive, but cannot read directly.</p> <p>0xFF= KEYLOCK(FMC_KPKEYSTS [1]) is cleared to 0 at power-on or reset cycle.</p> <p>The others=KP KEYLOCK(FMC_KPKEYSTS [1]) is set to 1 at power-on or reset cycle. KPROM, LDROM and APROM are write-protected.</p> <p>If KPKEYENROM[0]=0, CONFIG is write-protected.</p> <p>If KPKEYENROM[1]=0, SPROM is write-protected.</p> <p><b>Note:</b> when KPKEYENROM is programmed to be a non-0xFF value by ISP functions, KEYLOCK (FMC_KPKEYSTS [1]) will be enable immediately.</p> |

**KPCNTROM (Address = 0x0030\_1200)**

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [7:0]  | KPCNTROM    | <p><b>Power-on Counting for Error Key Entry (Write Only)</b></p> <p>KPCNTROM is used to count the number of the chip power-on/off operation if KPROM KEY is unmatched. FMC will clear one bit (decoding from KPCNT) after the first KEY is unmatched in KEY comparison operation. KPCNTROM is erased by hardware while KP KEY is matched, and cannot read out directly. KPCNTROM (8-bit) is encoded to 3-bit and stored into KPCNT(FMC_KPCNT[2:0]) at power-on or reset cycle, list below</p> <p>KPCNTROM → KPCNT</p> <p>1111_1111 → 000<br/>     1111_1110 → 001<br/>     1111_1100 → 010<br/>     1111_1000 → 011<br/>     1111_0000 → 100<br/>     1110_0000 → 101<br/>     1100_0000 → 110<br/>     1000_0000 → 111<br/>     The others → 111</p> |

**6.4.4.7 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-6.

|             | Reserved                            | Reserved                            | Reserved                            |
|-------------|-------------------------------------|-------------------------------------|-------------------------------------|
| 0x0080_7FFF | Boot Loader (32KB)                  | Boot Loader (32KB)                  | Boot Loader (32KB)                  |
| 0x0080_0000 | Reserved                            | Reserved                            | Reserved                            |
| 0x0031_0BFF | OTP (3KB)                           | OTP (3KB)                           | OTP (3KB)                           |
| 0x0031_0000 | Reserved                            | Reserved                            | Reserved                            |
| 0x0030_2FFF | Key Protection (KROM 8KB)           | Key Protection (KROM 8KB)           | Key Protection (KROM 8KB)           |
| 0x0030_1000 | Reserved                            | Reserved                            | Reserved                            |
| 0x0030_000F | User Configuration (16B)            | User Configuration (16B)            | User Configuration (16B)            |
| 0x0030_0000 | Reserved                            | Reserved                            | Reserved                            |
| 0x0020_0FFF | Security Protection ROM (SPROM 4KB) | Security Protection ROM (SPROM 4KB) | Security Protection ROM (SPROM 4KB) |
| 0x0020_0000 | Reserved                            | Reserved                            | Reserved                            |
| 0x0010_0FFF | Loader ROM (LDROM 4KB)              | Loader ROM (LDROM 4KB)              | Loader ROM (LDROM 4KB)              |
| 0x0010_0000 | Reserved                            | Reserved                            | Reserved                            |
| 0x0007_FFFF | Reserved                            | Reserved                            | ApplicationROM (APROM)              |
| 0x0001_FFFF | ApplicationROM (APROM)              | ApplicationROM (APROM)              |                                     |
| 0x0000_0000 |                                     |                                     |                                     |

APROM 128KB Device      APROM 256KB Device      APROM 512KB Device

Figure 6.4-6 Flash Memory Map

#### 6.4.4.8 System Memory Map with IAP Mode

The system memory map is used by CPU to fetch code or data from FMC memory. Boot Loader(0x0080\_0000~0x0080\_7FFF), SPROM(0x0020\_0000~0x0020\_0FFF) and LDROM(0x0010\_0000~0x0010\_0FFF) address map are the same as in the Flash memory map. The Data Flash is shared with APROM and the Data Flash base address is defined by CONFIG1. The content of CONFIG1 is loaded into DFBA (Data Flash Base Address Register) at the Flash initiation.

The DFBA-(0x0000\_FFFF/0x0001\_FFFF/0x0003\_FFFF/ 0x0005\_FFFF/0x0007\_FFFF) is the Data Flash region for Cortex®-M4 data access, and 0x0000\_0200~(DFBA-1) is APROM region for Cortex®-M4 instruction access when APROM size is 64KB/128KB/256KB/384KB/512KB, respectively.

The address from 0x0000\_0000 to 0x0000\_01FF is called system memory vector.

Figure 6.4-7 shows the system memory map with IAP mode.

APROM and LDROM can map to the system memory vector for CPU start up. There are three kinds of system memory map with IAP mode when chip booting: (1) LDROM with IAP and (2) APROM with IAP, and (3) Boot Loader with IAP.

|             |                                           |
|-------------|-------------------------------------------|
| 0x0080_7FFF | Reserved                                  |
| 0x0080_0000 | Boot Loader<br>(32KB)                     |
| 0x0031_0BFF | Reserved                                  |
| 0x0031_0000 | OTP<br>(4KB)                              |
| 0x0030_2FFF | Reserved                                  |
| 0x0030_1000 | Key Protection<br>(KROM 8KB)              |
| 0x0020_0FFF | Reserved                                  |
| 0x0020_0000 | Security Protection<br>ROM<br>(SPROM 4KB) |
| 0x0010_0FFF | Reserved                                  |
| 0x0010_0000 | Loader ROM<br>(LDROM 4KB)                 |
| 0x0007_FFFF | Reserved                                  |
| DFBA        | Data Flash                                |
| 0x0000_0200 | ApplicationROM<br>(APROM)                 |
| 0x0000_01FF | System Memory Vector                      |
| 0x0000_0000 |                                           |

Figure 6.4-7 System Memory Map with IAP Mode

In LDROM with IAP mode, the LDROM (0x0010\_0000~0x0010\_01FF) is mapping to the system memory vector for Cortex®-M4 instruction or data access. Figure 6.4-8 shows the memory map of LDROM with IAP mode.



Figure 6.4-8 LDROM with IAP Mode

In APROM with IAP mode, the APROM (0x0000\_0000~0x0000\_01FF) is mapping to the system memory vector for Cortex®-M4 instruction or data access. Figure 6.4-9 shows the memory map of APROM with IAP mode.



Figure 6.4-9 APROM with IAP Mode

In Boot Loader with IAP mode, the Boot Loader (0x0080\_0000~0x0080\_01FF) is mapping to the system memory vector for Cortex®-M4 instruction or data access. Figure 6.4-10 shows the memory map of Boot Loader with IAP mode.



Figure 6.4-10 Boot Loader with IAP Mode

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

#### 6.4.4.9 System Memory Map Without IAP Mode

In system memory map without IAP mode, CPU still can access Boot Loader(0x0080\_0000~0x0080\_7FFF) and SPROM(0x0020\_0000~0x0020\_0FFF), but the system memory vector mapping is not supported. There are two kinds of system memory map without IAP mode when chip booting: (1) LDROM without IAP, (2) APROM without IAP. In LDROM without IAP mode, LDROM base is mapping to 0x0000\_0000. CPU program cannot run to access APROM. In APROM without IAP mode, APROM base is mapping to 0x0000\_0000. CPU program cannot run to access LDROM. The Data Flash is shared with APROM and the Data Flash base address is defined by CONFIG1. The content of CONFIG1 is loaded into DFBA (Data Flash Base Address Register) at the Flash initiation. The DFBA~(0x0000\_FFFF/0x0001\_FFFF/0x0003\_FFFF/0x0005\_FFFF /0x0007\_FFFF) is the Data Flash region for Cortex®-M4 data access, and 0x0000\_0000~(DFBA-1) is APROM region for Cortex®-M4 instruction access when APROM size is 64KB/128KB/256KB/384KB/512KB, respectively. Figure 6.4-11 shows the system memory map without IAP mode.



Figure 6.4-11 System Memory Map without IAP Mode

#### 6.4.4.10 Boot Selection

The M480 series provides five booting sources for user to select, including LDROM with IAP, LDROM without IAP, APROM with IAP, APROM without IAP, and Boot Loader with IAP. To make CPU fetches code from Boot Loader, user can use the following two methods: MBS (CONFIG0[5]) is low or SBLOCK (CONFIG2[15:8]) is not 0x5A. In other cases, the booting source and system memory map are setting by CBS (CONFIG0[7:6]) and MBS (CONFIG0[5]).

The boot source selection diagram is shown in Figure 6.4-12 and each boot selection support vector mapping is shown in Table 6.4-2.



Figure 6.4-12 Boot Source Selection

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

Table 6.4-2 Vector Mapping Support

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

The M480 series provides In-Application-Programming (IAP) function for user to switch the system memory vector code executing between APROM, LDROM and Boot Loader. User can enable the IAP function by booting chip and setting the chip boot selection bits in CBS (CONFIG0[7:6]) as 10 or 00, in MBS (CONFIG0[5]) as 0, or in SBLOCK (CONFIG2[15:8]) as a non-0x5A value. (If MSB(CONFIG0[5]) bit is set as 0 or perform secure boot, the CBS[0] (FMC\_ISPSTS[1]) registers will show 0 and ignore CONFIG0[6] setting).

When chip boots with IAP function is enabled, any executable code (align to 512 bytes) is allowed to map to the system memory vector any time. User can change the remap address to FMC\_ISPADDR and then trigger ISP procedure with the “Vector Remap” command.

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

The M480 series supports In-System-Programming (ISP) function allowing the embedded Flash memory to be reprogrammed under software control. ISP is performed without removing the microcontroller from the system through the firmware and on-chip connectivity interface, such as UART, USB, I<sup>2</sup>C, SPI, and CAN (depended on chip feature). The target Flash memory space that ISP function operates cannot be across banks. Table 6.4-3 lists all ISP commands.

The 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_MPDATA0~FMC_MPDATA3                                                                                                                |
|-------------------------------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Flash Page Erase                                                                    | 0x22       | Valid address of Flash memory organization. It must be page (4 Kbytes) alignment. Note that FMC_ISPADDR[11:0] will be ignored. | N/A                                                                                                                                                  |
| Flash Bank Erase                                                                    | 0x23       | Valid address of APROM of the target bank. Note that FMC_ISPADDR[15:0] will be ignored.                                        | N/A                                                                                                                                                  |
| Flash Block Erase                                                                   | 0x25       | Valid address of APROM. It must be 4 pages (16 Kbytes) alignment. Note that FMC_ISPADDR[13:0] will be ignored.                 | N/A                                                                                                                                                  |
| Flash Mass Erase<br>(This command is only valid while MERASE(CONFIG0[13]) bit = 0.) | 0x26       | 0x0000_0000                                                                                                                    | N/A                                                                                                                                                  |
| Flash 32-bit Program                                                                | 0x21       | Valid address of Flash memory organization                                                                                     | FMC_ISPDAT :Programming Data                                                                                                                         |
| Flash 64-bit Program                                                                | 0x61       | Valid address of Flash memory organization                                                                                     | FMC_MPDATA0: LSB Programming Data<br>FMC_MPDATA1: MSB Programming Data                                                                               |
| Flash Multi-Word Program                                                            | 0x27       | Valid address of Flash memory organization in APROM, LDROM and SPROM                                                           | FMC_MPDATA0: 1'st Programming Data<br>FMC_MPDATA1: 2'nd Programming Data<br>FMC_MPDATA2: 3'rd Programming Data<br>FMC_MPDATA3: 4'th Programming Data |
| Flash Read                                                                          | 0x00       | Valid address of Flash memory organization                                                                                     | FMC_ISPDAT: Return Data                                                                                                                              |
| Flash 64-bit Read                                                                   | 0x40       | Valid address of Flash memory organization                                                                                     | FMC_ISPDAT: Return Data in FMC_ISPADDR<br>FMC_MPDATA0: Return Data in FMC_ISPADDR<br>FMC_MPDATA1: Return Data in FMC_ISPADDR+4                       |
| Read Company ID                                                                     | 0x0B       | 0x0000_0000                                                                                                                    | FMC_ISPDAT: 0x0000_00DA                                                                                                                              |

|                                |      |                                                                                  |                                                                                                   |
|--------------------------------|------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| Read Device ID                 | 0x0C | 0x0000_0000                                                                      | FMC_ISPDAT: Return Device ID                                                                      |
| Read CRC32 Checksum            | 0x0D | 0x0000_0000                                                                      | FMC_ISPDAT: Return Checksum                                                                       |
| Run CRC32 Checksum Calculation | 0x2D | Valid start address of memory organization<br>It must be 4 Kbytes page alignment | FMC_ISPDAT: Size<br>It must be 4 Kbytes alignment                                                 |
| Read Flash All One Result      | 0x08 | Keep address of "Run Flash All One Verification"                                 | FMC_ISPDAT: Return Result<br>0xA110_0000 : Flash is not all one<br>0xA11F_FFFF: Flash is all one. |
| Run Flash All One Verification | 0x28 | Valid start address of memory organization<br>It must be 4 Kbytes page alignment | FMC_ISPDAT: Size<br>It must be 4 Kbytes alignment                                                 |
| Read Unique ID                 | 0x04 | 0x0000_0000                                                                      | FMC_ISPDAT: Unique ID Word 0                                                                      |
|                                |      | 0x0000_0004                                                                      | FMC_ISPDAT: Unique ID Word 1                                                                      |
|                                |      | 0x0000_0008                                                                      | FMC_ISPDAT: Unique ID Word 2                                                                      |
| Vector Remap                   | 0x2E | Valid address in APROM, LDROM or boot loader<br>It must be 512 bytes alignment   | N/A                                                                                               |

Table 6.4-3 ISP Command List

### ISP Procedure

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

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

Once the FMC\_ISPCTL register is set properly, user can set FMC\_ISPCMD (refer to Table 6.4-3 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. The ISP procedure flow is shown in Figure 6.4-13.



Figure 6.4-13 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]) be 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.

When the ISPGO(FMC\_ISPTRG[0]) bit is set and then CPU access the same bank, CPU will wait for ISP operation to finish during this period; the peripheral still keeps working as usual. If any interrupt request occurs, CPU will not service it till ISP operation is finished. When ISP operation is finished, the ISPGO bit will be cleared by hardware automatically. User can check whether ISP operation is finished or not by the ISPGO(FMC\_ISPTRG[0]) bit.

When CPU access operation and ISP command are executed in different bank, CPU and ISP command can operate in parallel.

#### 6.4.4.13 Embedded Flash Memory Programming

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

| Register    | Description          | 32-Bit Programming | 64-Bit Programming | Multi-Word Programming |
|-------------|----------------------|--------------------|--------------------|------------------------|
| FMC_ISPCTL  | ISP Control Register | ✓                  | ✓                  | ✓                      |
| FMC_ISPADDR | ISP Address Register | ✓                  | ✓                  | ✓                      |

|             |                           |      |      |      |
|-------------|---------------------------|------|------|------|
| FMC_ISPDAT  | ISP Data Register         | ✓    | N/A  | N/A  |
| FMC_ISPCMD  | ISP Command Register      | 0x21 | 0x61 | 0x27 |
| FMC_ISPTRG  | ISP Trigger Register      | ✓    | ✓    | ✓    |
| FMC_ISPSTS  | ISP Status Register       | ✓    | ✓    | N/A  |
| FMC_MPDATA0 | ISP Data0 Register        | N/A  | ✓    | ✓    |
| FMC_MPDATA1 | ISP Data1 Register        | N/A  | ✓    | ✓    |
| FMC_MPDATA2 | ISP Data2 Register        | N/A  | N/A  | ✓    |
| FMC_MPDATA3 | ISP Data3 Register        | N/A  | N/A  | ✓    |
| FMC_MPSTA   | ISP Multi-Program status  | N/A  | N/A  | ✓    |
| FMC_MPADDR  | ISP Multi-Program Address | N/A  | N/A  | ✓    |

Table 6.4-4 FMC Control Registers for Flash Programming

**64-bit Programming**

The M480 series 64-bit programming function is faster than 32-bit programming. FMC\_ISPDAT is used for 32-bit programming data register. In 64-bit programming, there are two programming data registers, one is FMC\_MPDATA0 for LSB word, and the other is FMC\_MPDATA1 for MSB word, and ISP command is 0x61, the other registers are the same as 32-bit programming. Figure 6.4-14 and Figure 6.4-15 are the ISP 32-bit / 64-bit programming procedure flow.



Figure 6.4-14 ISP 32-bit Programming Procedure



Figure 6.4-15 ISP 64-bit Programming Procedure

### Multi-word Programming

The M480 series supports multi-word programming function to speed up Flash updated procedure. The maximum programming length is up to 512 bytes, and the minimum programming length is 8 bytes (2 words). The multi-word programming is the fastest programming function if the programming words more than 8 bytes, because only one set of Flash setup time and hold time needed for one time operation. Figure 6.4-16 compares each programming time.



Figure 6.4-16 Multi-word Programming Time

In multi-word programming operation, Cortex®-M4 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, or SPROM, because CPU instruction fetch cannot be hold. The firmware has to be located in Boot loader or embedded SRAM of chip to avoid CPU hold.



Figure 6.4-17 Firmware in Boot Loader for Multi-word Programming

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



Figure 6.4-18 Multi-word Programming Flow

#### 6.4.4.14 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-19.

The M480 series 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-19.



Figure 6.4-19 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 the M480 series, it only reads FMC\_ISPSTS to check PGFF flag in Step (3) without reading data back to confirm. Figure 6.4-20 compares traditional programming verification flow and fast programming verification flow.



Figure 6.4-20 Verification Flow

The fast Flash programming verification function is released for 32-bit programming and 64-bit programming operation, but multi-word programming operation is not suitable due to the embedded Flash HV (High Voltage) of continue programming.

#### 6.4.4.15 CRC32 Checksum Calculation

The M480 series supports the CRC32 checksum calculation function to help user quickly check the memory content includes APROM, LDROM and SPROM. The CRC32 polynomial is

$$\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$$

With seed = 0xFFFF\_FFFF

The CRC32 checksum calculation flow is shown in Figure 6.4-21.



Figure 6.4-21 Flash CRC32 Checksum Calculation

Three steps complete this CRC32 checksum calculation.

1. Step 1.Perform ISP “Run Memory CRC32 Checksum” operation
2. Step 2.Perform ISP “Read Memory CRC32 Checksum” operation
3. Step 3..Read FMC\_ISPDAT to get checksum.

In Step 1, user has to set the memory starting address (FMC\_ISPADDR) and size (FMC\_ISPDAT) to

calculate. Both address and size have to be 4 Kbytes alignment, the size should be  $\geq$  4 Kbytes and the starting address includes APROM, LDROM, SPROM and Boot Loader.

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

In Step 3, the checksum is read from FMC\_ISPDAT. If the checksum is 0x0000\_0000, there is one of two conditions (1) Checksum calculation is in-progress, (2) Address and size is over device limitation

When SPROM is locked to be security code, user cannot read the SPROM content directly; user can use this CRC32 checksum function to check SPROM content correction.

Note that the range of CRC32 checksum cannot cross bank in one operation.

#### 6.4.4.16 Flash All One Verification

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

Two or Three steps complete this Flash all one verification.

Two-step flow:

1. Step 1.Perform ISP “Run Flash All One Verification” operation
2. Step 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.

Three-step flow:

3. Step 1.Perform ISP “Run Flash All One Verification” operation
4. Step 2.Perform ISP “Read Flash All One Result” operation
5. Step 3..Read FMC\_ISPDAT to get the verification result.

FMC\_ISPDAT : 0xA11F\_FFFF, all of Flash bits are 1 in verification block memory.

FMC\_ISPDAT : 0xA110\_0000, 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 4 Kbytes alignment, the size should be  $\geq$  4 Kbytes and the starting address includes APROM, LDROM and SPROM.

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

Note that the range of “Run All One Verification” cannot cross bank in one operation.

#### 6.4.4.17 Security Key Protection

The M480 series supports the Security Key protection function to protect data of APROM, LDROM, SPROM, CONFIG and KPROM for program and erase command. While KEYLOCK (FMC\_KPKEYSTS [1]) is active, KPROM, LDROM and APROM (except Data Flash) are at write-protected state. SPROM and CONFIG are optional for write protected based on value of KPKEYENROM[1:0], any programming and page erasing operation are illegal except whole chip mass erase operation. If the data of APROM, LDROM, SPROM, CONFIG and KPROM need to be modified, the correct Key Comparison operation must be executed in advance to clear KEYLOCK (FMC\_KPKEYSTS [1]) status. When Flash data is locked by KEYLOCK, user can look the lock effect of FMC up in lock effect tables.

#### Security Key Setup Flow

The Security Key setup flow is shown in Figure 6.4-22. All of security key information is stored in KPROM. Firstly, the KPROM (8KB) has to perform erase operation to disable security key and then program three security keys in KPKEY0ROM, KPKEY1ROM and KPKEY2ROM. Continuously program KPMAXROM and KPKEMAXROM to define retry limitation of the security key comparison. KPMAXROM is used to limit the number of power-on if the security key comparison is unmatched. KPKEMAXROM is used to limit the number of key unmatched operation in each power-on. Finally, program a non-0xFF value into KPKEYENROM to enable security key protection function. KPROM data is unreadable, data cannot read back to check. The only way to check the security key is to execute the Key Comparison operation.



Figure 6.4-22 Flash Security Key Setup Flow

### Key Comparison Operation Flow

The Key Comparison function checks the user keys and the security keys in KPROM. The operation flow is shown in Figure 6.4-23.

1. Step 1. Write the user keys into FMC\_KPKEY0/FMC\_KPKEY1/FMC\_KPKEY2 registers
2. Step 2. Set 1 to KPKEYGO (FMC\_KPKEYTRG [0]) to start the comparison operation.
3. Step 3. FMC controller reads the security keys in KPROM and compares user keys.

If the comparison is matched, the unmatched counting register (FMC\_KPKECNT) will be cleared to 0 and the KPCNTROM page in KPROM will be erased. If the comparison is unmatched, the unmatched counting register (FMC\_KPKECNT and FMC\_KPCNT) is increased, and program 0 to KPCNTROM in KPROM.

4. Step 4. Hardware updates the status flag and compared result to FMC\_KPKEYSTS for user read.

If the KEYS are matched, KEYMATCH (FMC\_KPKEYSTS [2]) will be set to 1, and clear KEYLOCK (FMC\_KPKEYSTS [1]) to 0. KEYLOCK will keep 0 about 10~30 minutes, and then return to 1 automatically while KEYFLAG (FMC\_KPKEYSTS [4]) is active.



Figure 6.4-23 Key Comparison Flow

## 6.4.4.18 Lock Effect Tables

The M480 series supports four kinds of protections include the Security Lock Control (i.e., LOCK in CONFIG0[1] and ALOCK in CONFIG2[7:0]), Security Key protection function (i.e., KPROM and abbreviated to KEYLOCK), Secure boot (i.e., SBLOCK in CONFIG2[15:8]) and Security Protection Memory (i.e., SPROM and abbreviated to SPLOCK). In this section, M480 prepares some lock effect tables for user to understand the lock effects on APROM, LDROM, SPROM CONFIG and others with above four protections for CPU, ICE and ICP/Writer. Table 6.4-5 and Table 6.4-6 are the lock effect table for CPU and for ICE, ICP and Writer

| LOCK/ALOCK       | OFF |                | ON  |                | OFF |                | OFF            |                | OFF |                |    |                |   |                |
|------------------|-----|----------------|-----|----------------|-----|----------------|----------------|----------------|-----|----------------|----|----------------|---|----------------|
| KEYLOCK          | OFF |                | OFF |                | OFF |                | OFF            |                | ON  |                |    |                |   |                |
| KPKEYENROM[1:0]  | X   |                | X   |                | X   |                | X              |                | 00  | 01             | 10 |                |   |                |
| SBLOCK           | OFF |                | OFF |                | ON  |                | OFF            |                | OFF |                |    |                |   |                |
| SPLOCK           | OFF |                | OFF |                | OFF |                | ON             |                | OFF |                |    |                |   |                |
| APROM            | R   | W              | R   | W              | R   | W              | R              | W              | R   | -              | R  | -              | R | -              |
| Data Flash       | R   | W              | R   | W              | R   | W              | R              | W              | R   | W              | R  | W              | R | W              |
| LDROM            | R   | W              | R   | W              | R   | W              | R              | W              | R   | -              | R  | -              | R | -              |
| SPROM            | R   | W              | R   | W              | R   | W              | R <sub>1</sub> | W <sub>1</sub> | R   | -              | R  | -              | R | W              |
| CFG              | R   | W              | R   | W              | R   | W              | R              | W              | R   | -              | R  | W              | R | -              |
| KPROM            | -   | W              | -   | W              | -   | W              | -              | W              | -   | -              | -  | -              | - | -              |
| OTP              | R   | W <sub>2</sub> | R   | W <sub>2</sub> | R   | W <sub>2</sub> | R              | W <sub>2</sub> | R   | W <sub>2</sub> | R  | W <sub>2</sub> | R | W <sub>2</sub> |
| Secure Boot Key  | -   | W              | -   | W              | -   | W              | -              | W              | -   | W              | -  | W              | - | W              |
| Boot Loader      | R   | -              | R   | -              | R   | -              | R              | -              | R   | -              | R  | -              | R | -              |
| DID/UID/Checksum | R   | -              | R   | -              | R   | -              | R              | -              | R   | -              | R  | -              | R | -              |

Table 6.4-5 Lock Effect Table with Four Protections for CPU

| LOCK/ALOCK       | OFF |                | ON  |   | OFF |   | OFF |                | OFF |                |    |                |   |                |
|------------------|-----|----------------|-----|---|-----|---|-----|----------------|-----|----------------|----|----------------|---|----------------|
| KEYLOCK          | OFF |                | OFF |   | OFF |   | OFF |                | ON  |                |    |                |   |                |
| KPKEYENROM[1:0]  | X   |                | X   |   | X   |   | X   |                | 00  | 01             | 10 |                |   |                |
| SPLOCK           | OFF |                | OFF |   | OFF |   | ON  |                | OFF |                |    |                |   |                |
| APROM            | R   | W              | -   | - | -   | - | R   | W              | R   | -              | R  | -              | R | -              |
| Data Flash       | R   | W              | -   | - | -   | - | R   | W              | R   | W              | R  | W              | R | W              |
| LDROM            | R   | W              | -   | - | -   | - | R   | W              | R   | -              | R  | -              | R | -              |
| SPROM            | R   | W              | -   | - | -   | - | D   | -              | R   | -              | R  | -              | R | W              |
| CFG              | R   | W              | R   | - | R   | - | R   | W              | R   | -              | R  | W              | R | -              |
| OTP              | R   | W <sub>2</sub> | -   | - | -   | - | R   | W <sub>2</sub> | R   | W <sub>2</sub> | R  | W <sub>2</sub> | R | W <sub>2</sub> |
| KPROM            | -   | W              | -   | - | -   | - | -   | W              | -   | -              | -  | -              | - | -              |
| DID/UID/Checksum | R   | -              | R   | - | R   | - | R   | -              | R   | -              | R  | -              | R | -              |

Table 6.4-6 Lock Effect Table with Four Protections for ICE/ ICP/Writer

**Note:**

1. The symbol "R" means readable and the symbol "W" means writable.
2. The symbol "X" means no matter what value is.
3. The symbol " $R_1$ " means SPROM readable for CPU instruction, but unreadable for CPU data or ISP command. The symbol " $W_1$ " means SPROM cannot Program, but can PageErase. The symbol "D" means SPROM can be in debug mode for ICE (unreadable, return 0x0000\_0000).
4. The symbol " $W_2$ " means OTP is writable only when the corresponding "LOCK BIT" is 0xFFFF\_FFFF.
5. SBLOCK = LOCK/ALOCK for CPU and ICP/Writer.
6. All operations (except for MassErase) are invalid for ICE when SBLOCK is not 0x5A.
7. MassErase (i.e. whole chip erase) can be executed any time and any address, except for SPROM.
8. When any protection conflicts with another, FMC will adopt the most stringent one. For example, APROM is readable for ICE when KEYLOCK is on. Once both KEYLOCK and LOCK are on, APROM will be un-readable for ICE.
9. KPROM and secure boot key are un-readable for CPU, ICE and ICP/Writer.
10. Boot loader is un-readable for ICE and ICP/Writer.

#### 6.4.5 Register Map

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

| Register                    | Offset      | R/W | Description                                    | Reset Value |
|-----------------------------|-------------|-----|------------------------------------------------|-------------|
| <b>FMC Base Address</b>     |             |     |                                                |             |
| <b>FMC_BA = 0x4000_C000</b> |             |     |                                                |             |
| <b>FMC_ISPCTL</b>           | FMC_BA+0x00 | R/W | ISP Control Register                           | 0x0000_0000 |
| <b>FMC_ISPADDR</b>          | FMC_BA+0x04 | R/W | ISP Address Register                           | 0x0000_0000 |
| <b>FMC_ISPDAT</b>           | FMC_BA+0x08 | R/W | ISP Data Register                              | 0x0000_0000 |
| <b>FMC_ISPCMD</b>           | FMC_BA+0x0C | R/W | ISP Command Register                           | 0x0000_0000 |
| <b>FMC_ISPTRG</b>           | FMC_BA+0x10 | R/W | ISP Trigger Control Register                   | 0x0000_0000 |
| <b>FMC_DFBA</b>             | FMC_BA+0x14 | R   | Data Flash Base Address                        | 0xXXXX_XXXX |
| <b>FMC_ISPSTS</b>           | FMC_BA+0x40 | R/W | ISP Status Register                            | 0x0000_0000 |
| <b>FMC_CYCCTL</b>           | FMC_BA+0x4C | R/W | Flash Access Cycle Control Register            | 0x0000_0000 |
| <b>FMC_KPKEY0</b>           | FMC_BA+0x50 | W   | KPROM KEY0 Data Register                       | 0x0000_0000 |
| <b>FMC_KPKEY1</b>           | FMC_BA+0x54 | W   | KPROM KEY1 Data Register                       | 0x0000_0000 |
| <b>FMC_KPKEY2</b>           | FMC_BA+0x58 | W   | KPROM KEY2 Data Register                       | 0x0000_0000 |
| <b>FMC_KPKEYTRG</b>         | FMC_BA+0x5C | R/W | KPROM KEY Comparison Trigger Control Register  | 0x0000_0000 |
| <b>FMC_KPKEYSTS</b>         | FMC_BA+0x60 | R/W | KPROM KEY Comparison Status Register           | 0x0000_0000 |
| <b>FMC_KPKEYCNT</b>         | FMC_BA+0x64 | R   | KPROM KEY-Unmatched Counting Register          | 0x0000_XX00 |
| <b>FMC_KPCNT</b>            | FMC_BA+0x68 | R   | KPROM KEY-Unmatched Power-On Counting Register | 0x0000_0X00 |
| <b>FMC_MPDATA0</b>          | FMC_BA+0x80 | R/W | ISP Data0 Register                             | 0x0000_0000 |
| <b>FMC_MPDATA1</b>          | FMC_BA+0x84 | R/W | ISP Data1 Register                             | 0x0000_0000 |
| <b>FMC_MPDATA2</b>          | FMC_BA+0x88 | R/W | ISP Data2 Register                             | 0x0000_0000 |
| <b>FMC_MPDATA3</b>          | FMC_BA+0x8C | R/W | ISP Data3 Register                             | 0x0000_0000 |
| <b>FMC_MPSTS</b>            | FMC_BA+0xC0 | R   | ISP Multi-Program Status Register              | 0x0000_0000 |
| <b>FMC_MPADDR</b>           | FMC_BA+0xC4 | R   | ISP Multi-Program Address Register             | 0x0000_0000 |

#### 6.4.6 Register Description

##### ISP Control Register (FMC\_ISPCTL)

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [16]    | BL          | <p><b>Boot Loader Booting (Write Protect)</b></p> <p>This bit is initiated with the inverted value of MBS (CONFIG0[5]). Any reset, except CPU reset (CPU is 1) or system reset (SYS), BL will be reloaded. This bit is used to check chip boot from Boot Loader or not. User should keep original value of this bit when updating FMC_ISPCTL register.</p> <p>0 = Booting from APROM or LDROM.<br/>1 = Booting from Boot Loader.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [14:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [10:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | <b>ISPFF</b>  | <p><b>ISP Fail Flag (Write Protect)</b></p> <p>This bit is set by hardware when a triggered ISP meets any of the following conditions:</p> <p>This bit needs to be cleared by writing 1 to it.</p> <ul style="list-style-type: none"> <li>(1) APROM writes to itself if APUEN is set to 0.</li> <li>(2) LDROM writes to itself if LDUEN is set to 0.</li> <li>(3) CONFIG is erased/programmed if CFGUEN is set to 0.</li> <li>(4) SPROM is erased/programmed if SPUEN is set to 0</li> <li>(5) SPROM is programmed at SPROM secured mode.</li> <li>(6) Page Erase command at LOCK mode with ICE connection</li> <li>(7) Erase or Program command at brown-out detected</li> <li>(8) Destination address is illegal, such as over an available range.</li> <li>(9) Invalid ISP commands</li> <li>(10) Vector address is mapping to SPROM region</li> <li>(11) KPROM is erased/programmed if KEYLOCK is set to 1</li> <li>(12) APROM(except for Data Flash) is erased/programmed if KEYLOCK is set to 1</li> <li>(13) LDROM is erased/programmed if KEYLOCK is set to 1</li> <li>(14) SPROM is erased/programmed if KEYLOCK is set to 1 and KEYENROM[1:0] are 1.</li> <li>(15) CONFIG is erased/programmed if KEYLOCK is set to 1 and KEYENROM[1:0] are 1</li> </ul> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [5] | <b>LDUEN</b>  | <p><b>LDROM Update Enable Bit (Write Protect)</b></p> <p>0 = LDROM cannot be updated.<br/>1 = LDROM can be updated.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [4] | <b>CFGUEN</b> | <p><b>CONFIG Update Enable Bit (Write Protect)</b></p> <p>0 = CONFIG cannot be updated.<br/>1 = CONFIG can be updated.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [3] | <b>APUEN</b>  | <p><b>APROM Update Enable Bit (Write Protect)</b></p> <p>0 = APROM cannot be updated when the chip runs in APROM.<br/>1 = APROM can be updated when the chip runs in APROM.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [2] | <b>SPUEN</b>  | <p><b>SPROM Update Enable Bit (Write Protect)</b></p> <p>0 = SPROM cannot be updated.<br/>1 = SPROM can be updated.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [1] | <b>BS</b>     | <p><b>Boot Select (Write Protect)</b></p> <p>When MBS in CONFIG0 is 1, set/clear this bit to select next booting from LDROM/APROM, respectively. This bit also functions as chip booting status flag, which can be used to check where chip booted from. This bit is initiated with the inverted value of CBS[1] (CONFIG0[7]) after any reset is happened except CPU reset (CPU is 1) or system reset (SYS) is happened</p> <p>0 = Booting from APROM when MBS (CONFIG0[5]) is 1.<br/>1 = Booting from LDROM when MBS (CONFIG0[5]) is 1.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|     |              |                                                                                                                                                                                                                                                   |
|-----|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | <b>ISPEN</b> | <b>ISP Enable Bit (Write Protect)</b><br>ISP function enable bit. Set this bit to enable ISP function.<br>0 = ISP function Disabled.<br>1 = ISP function Enabled.<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
|-----|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**ISP Address (FMC\_ISPADDR)**

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

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | ISPADDR     | <p><b>ISP Address</b></p> <p>The M480 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.</p> <p>For CRC32 Checksum Calculation command, this field is the Flash starting address for checksum calculation, 4 Kbytes alignment is necessary for CRC32 checksum calculation.</p> <p>For Flash32-bit Program, ISP address needs word alignment (4-byte). For Flash 64-bit Program, ISP address needs double word alignment (8-byte).</p> |

ISP Data Register (FMC\_ISPDAT)

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

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | ISPDAT      | <p><b>ISP Data</b></p> <p>Write data to this register before ISP program operation.</p> <p>Read data from this register after ISP read operation.</p> <p>When ISPFF (FMC_ISPCTL[6]) is 1, ISPDAT = 0xffff_ffff. For Run CRC32 Checksum Calculation command, ISPDAT is the memory size (byte) and 4 Kbytes alignment. For ISP Read CRC32 Checksum command, ISPDAT is the checksum result. If ISPDAT = 0x0000_0000, it means that (1) the checksum calculation is in progress, or (2) the memory range for checksum calculation is incorrect.</p> |

**ISP Command Register (FMC\_ISPCMD)**

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

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [6:0]  | CMD         | <p><b>ISP Command</b></p> <p>ISP command table is shown below:</p> <ul style="list-style-type: none"> <li>0x00= FLASH Read.</li> <li>0x04= Read Unique ID.</li> <li>0x08= Read Flash All-One Result.</li> <li>0x0B= Read Company ID.</li> <li>0x0C= Read Device ID.</li> <li>0x0D= Read Checksum.</li> <li>0x21= FLASH 32-bit Program.</li> <li>0x22= FLASH Page Erase. Erase any page in two banks, except for OTP.</li> <li>0x23= FLASH Bank Erase. Erase all pages of APROM in BANK0 or BANK1.</li> <li>0x25= FLASH Block Erase. Erase four pages alignment of APROM in BANK0 or BANK1.</li> <li>0x27= FLASH Multi-Word Program.</li> <li>0x28= Run Flash All-One Verification.</li> <li>0x2D= Run Checksum Calculation.</li> <li>0x2E= Vector Remap.</li> <li>0x40= FLASH 64-bit Read.</li> <li>0x61= FLASH 64-bit Program.</li> </ul> <p>The other commands are invalid.</p> |

**ISP Trigger Control Register (FMC\_ISPTRG)**

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

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                              |
| [0]    | ISPGO       | <p><b>ISP Start Trigger (Write Protect)</b></p> <p>Write 1 to start ISP operation and this bit will be cleared to 0 by hardware automatically when ISP operation is finished.</p> <p>0 = ISP operation is finished.<br/>1 = ISP is progressed.</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |

Data Flash Base Address Register (FMC\_DFBA)

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

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

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

**ISP Status Register (FMC\_ISPSTS)**

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

|               |              |             |          |            |            |    |                |
|---------------|--------------|-------------|----------|------------|------------|----|----------------|
| 31            | 30           | 29          | 28       | 27         | 26         | 25 | 24             |
| <b>SCODE</b>  | Reserved     |             |          |            |            |    |                |
| 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              |
| <b>ALLONE</b> | <b>ISPFF</b> | <b>PGFF</b> | Reserved | <b>MBS</b> | <b>CBS</b> |    | <b>ISPBUSY</b> |

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

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]   | <b>ISPFF</b>    | <p><b>ISP Fail Flag (Write Protect)</b></p> <p>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:</p> <ul style="list-style-type: none"> <li>(1) APROM writes to itself if APUEN is set to 0.</li> <li>(2) LDROM writes to itself if LDUEN is set to 0.</li> <li>(3) CONFIG is erased/programmed if CFGUEN is set to 0.</li> <li>(4) SPROM is erased/programmed if SPUEN is set to 0</li> <li>(5) SPROM is programmed at SPROM secured mode.</li> <li>(6) Page Erase command at LOCK mode with ICE connection</li> <li>(7) Erase or Program command at brown-out detected</li> <li>(8) Destination address is illegal, such as over an available range.</li> <li>(9) Invalid ISP commands</li> <li>(10) Vector address is mapping to SPROM region.</li> <li>(11) KPROM is erased/programmed if KEYLOCK is set to 1</li> <li>(12) APROM(except for Data Flash) is erased/programmed if KEYLOCK is set to 1</li> <li>(13) LDROM is erased/programmed if KEYLOCK is set to 1</li> <li>(14) SPROM is erased/programmed if KEYLOCK is set to 1 and KEYENROM[1:0] are 1.</li> <li>(15) CONFIG is erased/programmed if KEYLOCK is set to 1 and KEYENROM[1:0] are 1.</li> </ul> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |
| [5]   | <b>PGFF</b>     | <p><b>Flash Program with Fast Verification Flag (Read Only)</b></p> <p>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</p> <p>0 = Flash Program is success.<br/>1 = Flash Program is fail. Program data is different with data in the Flash memory</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [4]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [3]   | <b>MBS</b>      | <p><b>Boot From Boot Loader Selection Flag (Read Only)</b></p> <p>This bit is initiated with the MBS (CONFIG0[5]) after any reset is happened except CPU reset (CPU is 1) or system reset (SYS) is happened</p> <p>0 = Booting from Boot Loader.<br/>1 = Booting from LDROM/APROM.(.see CBS bit setting)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [2:1] | <b>CBS</b>      | <p><b>Boot Selection of CONFIG (Read Only)</b></p> <p>This bit is initiated with the CBS (CONFIG0[7:6]) after any reset is happened except CPU reset (CPU is 1) or system reset (SYS) is happened.</p> <p>The following function is valid when MBS (FMC_ISPSTS[3])= 1.</p> <p>00 = LDROM with IAP mode.<br/>01 = LDROM without IAP mode.<br/>10 = APROM with IAP mode.<br/>11 = APROM without IAP mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [0]   | <b>ISPBUSY</b>  | <p><b>ISP Busy Flag (Read Only)</b></p> <p>Write 1 to start ISP operation and this bit will be cleared to 0 by hardware automatically when ISP operation is finished.</p> <p>This bit is the mirror of ISPGO(FMC_ISPTRG[0]).</p> <p>0 = ISP operation is finished.<br/>1 = ISP is progressed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**Flash Access Cyce Control Register (FMC\_CYCCTL)**

| Register   | Offset      | R/W | Description                         |  |  |  | Reset Value |
|------------|-------------|-----|-------------------------------------|--|--|--|-------------|
| FMC_CYCCTL | FMC_BA+0x4C | R/W | Flash Access Cycle 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 |    |    |    | CYCLE |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [3:0]  | CYCLE       | <p><b>Flash Access Cycle Control (Write Protect)</b></p> <p>This register is updated automatically by hardware while FCYCDIS (FMC_ISPSTS[4]) is 0, and updated by software while auto-tuning function disabled ( FADIS (FMC_CYCTL[8]) is 1)</p> <p>0000 = CPU access with zero wait cycle ; Flash access cycle is 1; The HCLK working frequency range is &lt;27MHz; Cache is disabled by hardware.</p> <p>0001 = CPU access with one wait cycle if cache miss; Flash access cycle is 1; The HCLK working frequency range is&lt;27MHz</p> <p>0010 = CPU access with two wait cycles if cache miss; Flash access cycle is 2; The optimized HCLK working frequency range is 27~54 MHz</p> <p>0011 = CPU access with three wait cycles if cache miss; Flash access cycle is 3; The optimized HCLK working frequency range is 54~81MHz</p> <p>0100 = CPU access with four wait cycles if cache miss; Flash access cycle is 4; The optimized HCLK working frequency range is81~108MHz</p> <p>0101 = CPU access with five wait cycles if cache miss; Flash access cycle is 5; The optimized HCLK working frequency range is 108~135MHz</p> <p>0110 = CPU access with six wait cycles if cache miss; Flash access cycle is 6;. The optimized HCLK working frequency range is 135~162MHz</p> <p>0111 = CPU access with seven wait cycles if cache miss; Flash access cycle is 7; The optimized HCLK working frequency range is 162~192MHz</p> <p>1000 = CPU access with eight wait cycles if cache miss; Flash access cycle is 8;. The optimized HCLK working frequency range is &gt;192MHz</p> <p><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> |

**KPROM KEY0 Data Register (FMC\_KPKEY0)**

| Register   | Offset      | R/W | Description              |  |  |  | Reset Value |
|------------|-------------|-----|--------------------------|--|--|--|-------------|
| FMC_KPKEY0 | FMC_BA+0x50 | W   | KPROM KEY0 Data Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                            |
|--------|-------------|------------------------------------------------------------------------------------------------------------|
| [31:0] | KPKEY0      | <b>KPROM KEY0 Data (Write Only)</b><br>Write KPKEY0 data to this register before KEY Comparison operation. |

**KPROM KEY1 Data Register (FMC\_KPKEY1)**

| Register   | Offset      | R/W | Description              | Reset Value |
|------------|-------------|-----|--------------------------|-------------|
| FMC_KPKEY1 | FMC_BA+0x54 | W   | KPROM KEY1 Data Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                            |
|--------|-------------|------------------------------------------------------------------------------------------------------------|
| [31:0] | KPKEY1      | <b>KPROM KEY1 Data (Write Only)</b><br>Write KPKEY1 data to this register before KEY Comparison operation. |

**KPROM KEY2 Data Register (FMC\_KPKEY2)**

| Register   | Offset      | R/W | Description              | Reset Value |
|------------|-------------|-----|--------------------------|-------------|
| FMC_KPKEY2 | FMC_BA+0x58 | W   | KPROM KEY2 Data Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                            |
|--------|-------------|------------------------------------------------------------------------------------------------------------|
| [31:0] | KPKEY2      | <b>KPROM KEY2 Data (Write Only)</b><br>Write KPKEY2 data to this register before KEY Comparison operation. |

**KPROM KEY Comparison Trigger Control Register (FMC\_KPKEYTRG)**

| Register     | Offset      | R/W | Description                                   |  |  |  | Reset Value |
|--------------|-------------|-----|-----------------------------------------------|--|--|--|-------------|
| FMC_KPKEYTRG | FMC_BA+0x5C | R/W | KPROM KEY Comparison Trigger Control Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [1]    | TCEN        | <b>Timeout Counting Enable Bit (Write Protect)</b><br>0 = Timeout counting Disabled.<br>1 = Timeout counting Enabled if input key is matched after key comparison finished.<br>10 minutes is at least for timeout, and average is about 20 minutes.<br><b>Note:</b> This bit is write-protected. Refer to the SYS_REGLCTL register.                                                                                                                   |
| [0]    | KPKEYGO     | <b>KPROM KEY Comparison Start Trigger (Write Protect)</b><br>Write 1 to start KEY comparison operation and this bit will be cleared to 0 by hardware automatically when KEY comparison operation is finished. This trigger operation is valid while FORBID (FMC_KPKEYSTS [3]) is 0.<br>0 = KEY comparison operation is finished.<br>1 = KEY comparison is progressed.<br><b>Note:</b> This bit is write-protected. Refer to the SYS_REGLCTL register. |

**KPROM KEY Status Register (FMC\_KPKEYSTS)**

| Register     | Offset      | R/W | Description                          |  |  |  | Reset Value |
|--------------|-------------|-----|--------------------------------------|--|--|--|-------------|
| FMC_KPKEYSTS | FMC_BA+0x60 | R/W | KPROM KEY Comparison 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 | SPFLAG | CFGFLAG | KEYFLAG | FORBID | KEYMATCH | KEYLOCK | KEYBUSY |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                   |
| [6]    | SPFLAG      | <b>SPROM Write-protection Enable Flag (Read Only)</b><br>This bit is set while the KEYENROM [1] is 0 at power-on or reset. This bit is cleared to 0 by hardware while KPROM is erased. This bit is set to 1 by hardware while KEYENROM[1] is programmed to 0.<br>0 = SPROM write-protection Disabled.<br>1 = SPROM write-protection Enabled.                |
| [5]    | CFGFLAG     | <b>CONFIG Write-protection Enable Flag (Read Only)</b><br>This bit is set while the KEYENROM [0] is 0 at power-on or reset. This bit is cleared to 0 by hardware while KPROM is erased. This bit is set to 1 by hardware while KEYENROM[0] is programmed to 0.<br>0 = CONFIG write-protection Disabled.<br>1 = CONFIG write-protection Enabled.             |
| [4]    | KEYFLAG     | <b>KEY Protection Enable Flag (Read Only)</b><br>This bit is set while the KEYENROM [7:0] is not 0xFF at power-on or reset. This bit is cleared to 0 by hardware while KPROM is erased. This bit is set to 1 by hardware while KEYENROM is programmed to a non-0xFF value.<br>0 = Security Key protection Disabled.<br>1 = Security Key protection Enabled. |
| [3]    | FORBID      | <b>KEY Comparison Forbidden Flag (Read Only)</b><br>This bit is set to 1 when KPKECNT(FMC_KPKEY0[4:0]) is more than KPKEMAX (FMC_KPKEY0[12:8]) or KPCNT (FMC_KPCNT [2:0]) is more than KPMAX (FMC_KPCNT [10:8]).<br>0 = KEY comparison is not forbidden.<br>1 = KEY comparison is forbidden, KEYGO (FMC_KEYTRG [0]) cannot trigger.                         |

|     |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | KEYMATCH | <b>KEY Match Flag (Read Only)</b><br>This bit is set to 1 after KEY comparison complete if the KEY0, KEY1 and KEY2 are matched with the 96-bit security keys in KPROM; and cleared to 0 if KEYs are unmatched. This bit is also cleared to 0 while <ul style="list-style-type: none"><li>● CPU writing 1 to KEYLOCK(FMC_KPKEYSTS[1]) or</li><li>● Timeout event or</li><li>● KPROM is erased or</li><li>● KEYENROM is programmed to a non-0xFF value.</li><li>● Chip is in Power-down mode.</li></ul> 0 = KEY0, KEY1, and KEY2 are unmatched with the KPROM setting.<br>1 = KEY0, KEY1, and KEY2 are matched with the KPROM setting.                                                                                                                                                                                      |
| [1] | KEYLOCK  | <b>KEY LOCK Flag</b><br>This bit is set to 1 if KEYMATCH (FMC_KPKEYSTS [2]) is 0 and cleared to 0 if KEYMATCH is 1 in Security Key protection. After Mass Erase operation, users must reset or power on /off to clear this bit to 0. This bit also can be set to 1 while: <ul style="list-style-type: none"><li>● CPU write 1 to KEYLOCK(FMC_KPKEYSTS[1]) or</li><li>● KEYFLAG(FMC_KPKEYSTS[4]) is 1 at power-on or reset or</li><li>● KEYENROM is programmed a non-0xFF value or</li><li>● Timeout event or</li><li>● FORBID(FMC_KPKEYSTS[3]) is 1</li></ul> 0 = KPROM, LDROM and APROM (not include Data Flash) is not in write protection.<br>1 = KPROM, LDROM and APROM (not include Data Flash) is in write protection.<br>SPROM write protect is depended on SPFLAG.<br>CONFIG write protect is depended on CFGFLAG |
| [0] | KEYBUSY  | <b>KEY Comparison Busy (Read Only)</b><br>0 = KEY comparison is finished.<br>1 = KEY comparison is busy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**KPROM KEY-unmatched Counting Register (FMC\_KPKEYCNT)**

| Register     | Offset      | R/W | Description                           |  |  |  | Reset Value |
|--------------|-------------|-----|---------------------------------------|--|--|--|-------------|
| FMC_KPKEYCNT | FMC_BA+0x64 | R   | KPROM KEY-Unmatched Counting Register |  |  |  | 0x0000_XX00 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                       |
| [13:8]  | KPKEMAX     | <b>Maximum Number for Error Key Entry at Each Power-on (Read Only)</b><br>KPKEMAX is the maximum error key entry number at each power-on. When KPKEMAXROM of KPROM is erased or programmed, KPKEMAX will also be updated. KPKEMAX is used to limit KPKECNT(FMC_KPKEY0[5:0]) maximum counting. The FORBID (FMC_KPKEYSTS [3]) will be set to 1 when KPKECNT is more than KPKEMAX. |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                       |
| [5:0]   | KPKECNT     | <b>Error Key Entry Counter at Each Power-on (Read Only)</b><br>KPKECNT is increased when entry keys is wrong in Security Key protection. KPKECNT is cleared to 0 if key comparison is matched or system power-on.                                                                                                                                                               |

**KPROM KEY-unmatched Power-on Counting Register (FMC\_KPCNT)**

| Register  | Offset      | R/W | Description                                    |  |  | Reset Value |
|-----------|-------------|-----|------------------------------------------------|--|--|-------------|
| FMC_KPCNT | FMC_BA+0x68 | R   | KPROM KEY-Unmatched Power-On Counting Register |  |  | 0x0000_0X00 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                  |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                        |
| [11:8]  | <b>KPMAX</b>    | <b>Power-on Maximum Number for Error Key Entry (Read Only)</b><br>KPROM is the power-on maximum number for error key entry. When KPROM of KPROM is erased or programmed, KPMAX will also be updated. KPMAX is used to limit KPCNT (FMC_KPCNT [3:0]) maximum counting. The FORBID(FMC_KPKEYSTS[3]) will be set to 1 when KPCNT is more than KPMAX |
| [7:4]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                        |
| [3:0]   | <b>KPCNT</b>    | <b>Power-on Counter for Error Key Entry (Read Only)</b><br>KPCNT is the power-on counting for error key entry in Security Key protection. KPCNT is cleared to 0 if key comparison is matched.                                                                                                                                                    |

**ISP Data 0 Register (FMC\_MPDATA0)**

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

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

| Bits   | Description    |                                                                                                                                                                            |
|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>ISPDAT0</b> | ISP Data 0<br>This register is the first 32-bit data for 32-bit/64-bit/multi-word programming, and it is also the 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+0x84 | R/W | ISP Data1 Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                          |
|--------|-------------|------------------------------------------------------------------------------------------|
| [31:0] | ISPDAT1     | ISP Data 1<br>This register is the second 32-bit data for 64-bit/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+0x8C | R/W | ISP Data3 Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------|
| [31:0] | ISPDAT3     | ISP Data 3<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 |  |  |  | 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      |
| D3       | D2 | D1 | D0 | Reserved | ISPFF | PPGO | MPBUSY |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [7]    | D3          | <b>ISP DATA 3 Flag (Read Only)</b><br>This bit is set when FMC_MPDAT3 is written and auto-clear to 0 when the FMC_MPDAT3 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          | <b>ISP DATA 2 Flag (Read Only)</b><br>This bit is set when FMC_MPDAT2 is written and auto-clear to 0 when the FMC_MPDAT2 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          | <b>ISP DATA 1 Flag (Read Only)</b><br>This bit is set when FMC_MPDAT1 is written and auto-clear to 0 when the FMC_MPDAT1 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          | <b>ISP DATA 0 Flag (Read Only)</b><br>This bit is set when FMC_MPDAT0 is written and auto-clear to 0 when the FMC_MPDAT0 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] | <b>ISPFF</b>  | <b>ISP Fail Flag (Read Only)</b><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>(1) APROM writes to itself if APUEN is set to 0.<br>(2) LDROM writes to itself if LDUEN is set to 0.<br>(3) CONFIG is erased/programmed if CFGUEN is set to 0.<br>(4) SPROM is erased/programmed if SPUEN is set to 0<br>(5) SPROM is programmed at SPROM secured mode.<br>(6) Page Erase command at LOCK mode with ICE connection<br>(7) Erase or Program command at brown-out detected<br>(8) Destination address is illegal, such as over an available range.<br>(9) Invalid ISP commands<br>(10) Vector address is mapping to SPROM region. |
| [1] | <b>PPGO</b>   | <b>ISP Multi-program Status (Read Only)</b><br>0 = ISP multi-word program operation is not active.<br>1 = ISP multi-word program operation is in progress.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [0] | <b>MPBUSY</b> | <b>ISP Multi-word Program Busy Flag (Read Only)</b><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 |  |  |  | 0x0000_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] | <b>MPADDR</b> | <b>ISP Multi-word Program Address</b><br>MPADDR is the address of ISP multi-word program operation when ISPGO flag is 1.<br>MPADDR will keep the final ISP address when ISP multi-word program is complete. |

## 6.5 General Purpose I/O (GPIO)

### 6.5.1 Overview

This chip has up to 118 General Purpose I/O pins to be shared with other function pins depending on the chip configuration. These 118 pins are arranged in 8 ports named as PA, PB, PC, PD, PE, PF, PG and PH. PA, PB, PE and PG has 16 pins on port. PC, PD has 15 pins on port. PF, PH has 12 pins on port. Each of the 118 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 (CONFIG0[10]).

### 6.5.2 Features

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

### 6.5.3 Block Diagram



Figure 6.5-1 GPIO Controller Block Diagram

**Note:** The PC.15/PD.15/PF.12/PF.13/PF.14/PF.15/PH.12/PH.13/PH.14/PH.15 pins are not available.

### 6.5.4 Basic Configuration

- Reset configuration
  - Reset GPIO in GPIO\_RST SYS\_IPRST1[1]
- Pin configuration

| Group | Pin Name | GPIO       | MFP   |
|-------|----------|------------|-------|
| INT0  | INT0     | PA.6, PB.5 | MFP15 |
| INT1  | INT1     | PA.7, PB.4 | MFP15 |
| INT2  | INT2     | PB.3, PC.6 | MFP15 |
| INT3  | INT3     | PB.2, PC.7 | MFP15 |
| INT4  | INT4     | PB.6       | MFP13 |
|       |          | PA.8       | MFP15 |
| INT5  | INT5     | PB.7       | MFP13 |
|       |          | PD.12      | MFP15 |
| INT6  | INT6     | PB.8       | MFP13 |
|       |          | PD.11      | MFP15 |
| INT7  | INT7     | PB.9       | MFP13 |
|       |          | PD.10      | MFP15 |

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

#### 6.5.5.2 Push-pull Output Mode

Figure 6.5-2 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-2 Push-Pull Output

#### 6.5.5.3 Open-drain Mode

Figure 6.5-3 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 drive a low output on the pin. If the bit value in the corresponding DOUT (Px\_DOUT[n]) bit is 1, the pin output drives high that is controlled by external pull high resistor.



Figure 6.5-3 Open-Drain Output

#### 6.5.5.4 Quasi-bidirectional Mode

Figure 6.5-4 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 drive a low output on the pin. If the bit value in the corresponding DOUT (Px\_DOUT[n]) bit is 1, the pin will check the pin value. If pin value is high, no action takes. If pin state is low, the pin will drive strong high with 2 clock cycles on the pin and then disable the strong output drive. Meanwhile, the pin status is controlled by internal pull-up resistor. Note that the source current capability in quasi-bidirectional mode is only about 200 uA to 30 uA for V<sub>DD</sub> is from 5.0 V to 2.5 V.



Figure 6.5-4 Quasi-Bidirectional I/O Mode

**Note:** When GPIO is configured as Quasi mode, it consumes 65uA fixedly as long as the potential is LOW.

#### 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 condition 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. 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 and are not supported in power down mode. For edge trigger condition, there are three types of interrupt condition can be selected for de-bounce function: falling edge trigger, rising edge trigger and both rising and falling edge trigger by setting correlative RHIEN (Px\_INTEN[n+16])/FLIEN (Px\_INTEN[n]) bit and TYPE (Px\_INTTYPE[n]). 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 (10kHz) 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-5 GPIO Rising Edge Trigger Interrupt



Figure 6.5-6 GPIO Falling Edge Trigger Interrupt

### 6.5.6 Register Map

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

| Register                     | Offset        | R/W | Description                                 | Reset Value |
|------------------------------|---------------|-----|---------------------------------------------|-------------|
| <b>GPIO Base Address:</b>    |               |     |                                             |             |
| <b>GPIO_BA = 0x4000_4000</b> |               |     |                                             |             |
| <b>PA_MODE</b>               | GPIO_BA+0x000 | R/W | PA I/O Mode Control                         | 0xFFFF_FFFF |
| <b>PA_DINOFF</b>             | GPIO_BA+0x004 | R/W | PA Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PA_DOUT</b>               | GPIO_BA+0x008 | R/W | PA Data Output Value                        | 0x0000_FFFF |
| <b>PA_DATMSK</b>             | GPIO_BA+0x00C | R/W | PA Data Output Write Mask                   | 0x0000_0000 |
| <b>PA_PIN</b>                | GPIO_BA+0x010 | R   | PA Pin Value                                | 0x0000_FFFF |
| <b>PA_DBEN</b>               | GPIO_BA+0x014 | R/W | PA De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PA_INTTYPE</b>            | GPIO_BA+0x018 | R/W | PA Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PA_INTEN</b>              | GPIO_BA+0x01C | R/W | PA Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PA_INTSRC</b>             | GPIO_BA+0x020 | R/W | PA Interrupt Source Flag                    | 0x0000_FFFF |
| <b>PA_SMTEN</b>              | GPIO_BA+0x024 | R/W | PA Input Schmitt Trigger Enable Register    | 0x0000_0000 |
| <b>PA_SLEWCTL</b>            | GPIO_BA+0x028 | R/W | PA High Slew Rate Control Register          | 0x0000_0000 |
| <b>PA_PUSEL</b>              | GPIO_BA+0x030 | R/W | PA Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>PB_MODE</b>               | GPIO_BA+0x040 | R/W | PB I/O Mode Control                         | 0xFFFF_FFFF |
| <b>PB_DINOFF</b>             | GPIO_BA+0x044 | R/W | PB Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PB_DOUT</b>               | GPIO_BA+0x048 | R/W | PB Data Output Value                        | 0x0000_FFFF |
| <b>PB_DATMSK</b>             | GPIO_BA+0x04C | R/W | PB Data Output Write Mask                   | 0x0000_0000 |
| <b>PB_PIN</b>                | GPIO_BA+0x050 | R   | PB Pin Value                                | 0x0000_FFFF |
| <b>PB_DBEN</b>               | GPIO_BA+0x054 | R/W | PB De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PB_INTTYPE</b>            | GPIO_BA+0x058 | R/W | PB Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PB_INTEN</b>              | GPIO_BA+0x05C | R/W | PB Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PB_INTSRC</b>             | GPIO_BA+0x060 | R/W | PB Interrupt Source Flag                    | 0x0000_FFFF |
| <b>PB_SMTEN</b>              | GPIO_BA+0x064 | R/W | PB Input Schmitt Trigger Enable Register    | 0x0000_0000 |
| <b>PB_SLEWCTL</b>            | GPIO_BA+0x068 | R/W | PB High Slew Rate Control Register          | 0x0000_0000 |
| <b>PB_PUSEL</b>              | GPIO_BA+0x070 | R/W | PB Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>PC_MODE</b>               | GPIO_BA+0x080 | R/W | PC I/O Mode Control                         | 0xFFFF_FFFF |
| <b>PC_DINOFF</b>             | GPIO_BA+0x084 | R/W | PC Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PC_DOUT</b>               | GPIO_BA+0x088 | R/W | PC Data Output Value                        | 0x0000_FFFF |

|                   |               |     |                                             |             |
|-------------------|---------------|-----|---------------------------------------------|-------------|
| <b>PC_DATMSK</b>  | GPIO_BA+0x08C | R/W | PC Data Output Write Mask                   | 0x0000_0000 |
| <b>PC_PIN</b>     | GPIO_BA+0x090 | R   | PC Pin Value                                | 0x0000_XXXX |
| <b>PC_DBEN</b>    | GPIO_BA+0x094 | R/W | PC De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PC_INTTYPE</b> | GPIO_BA+0x098 | R/W | PC Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PC_INTEN</b>   | GPIO_BA+0x09C | R/W | PC Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PC_INTSRC</b>  | GPIO_BA+0x0A0 | R/W | PC Interrupt Source Flag                    | 0x0000_XXXX |
| <b>PC_SMTEN</b>   | GPIO_BA+0x0A4 | R/W | PC Input Schmitt Trigger Enable Register    | 0x0000_0000 |
| <b>PC_SLEWCTL</b> | GPIO_BA+0x0A8 | R/W | PC High Slew Rate Control Register          | 0x0000_0000 |
| <b>PC_PUSEL</b>   | GPIO_BA+0x0B0 | R/W | PC Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>PD_MODE</b>    | GPIO_BA+0x0C0 | R/W | PD I/O Mode Control                         | 0xXXXX_XXXX |
| <b>PD_DINOFF</b>  | GPIO_BA+0x0C4 | R/W | PD Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PD_DOUT</b>    | GPIO_BA+0x0C8 | R/W | PD Data Output Value                        | 0x0000_FFFF |
| <b>PD_DATMSK</b>  | GPIO_BA+0x0CC | R/W | PD Data Output Write Mask                   | 0x0000_0000 |
| <b>PD_PIN</b>     | GPIO_BA+0x0D0 | R   | PD Pin Value                                | 0x0000_XXXX |
| <b>PD_DBEN</b>    | GPIO_BA+0x0D4 | R/W | PD De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PD_INTTYPE</b> | GPIO_BA+0x0D8 | R/W | PD Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PD_INTEN</b>   | GPIO_BA+0x0DC | R/W | PD Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PD_INTSRC</b>  | GPIO_BA+0x0E0 | R/W | PD Interrupt Source Flag                    | 0x0000_XXXX |
| <b>PD_SMTEN</b>   | GPIO_BA+0x0E4 | R/W | PD Input Schmitt Trigger Enable Register    | 0x0000_0000 |
| <b>PD_SLEWCTL</b> | GPIO_BA+0x0E8 | R/W | PD High Slew Rate Control Register          | 0x0000_0000 |
| <b>PD_PUSEL</b>   | GPIO_BA+0xF0  | R/W | PD Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>PE_MODE</b>    | GPIO_BA+0x100 | R/W | PE I/O Mode Control                         | 0xXXXX_XXXX |
| <b>PE_DINOFF</b>  | GPIO_BA+0x104 | R/W | PE Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PE_DOUT</b>    | GPIO_BA+0x108 | R/W | PE Data Output Value                        | 0x0000_FFFF |
| <b>PE_DATMSK</b>  | GPIO_BA+0x10C | R/W | PE Data Output Write Mask                   | 0x0000_0000 |
| <b>PE_PIN</b>     | GPIO_BA+0x110 | R   | PE Pin Value                                | 0x0000_XXXX |
| <b>PE_DBEN</b>    | GPIO_BA+0x114 | R/W | PE De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PE_INTTYPE</b> | GPIO_BA+0x118 | R/W | PE Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PE_INTEN</b>   | GPIO_BA+0x11C | R/W | PE Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PE_INTSRC</b>  | GPIO_BA+0x120 | R/W | PE Interrupt Source Flag                    | 0x0000_XXXX |
| <b>PE_SMTEN</b>   | GPIO_BA+0x124 | R/W | PE Input Schmitt Trigger Enable Register    | 0x0000_0000 |

|                   |               |     |                                             |             |
|-------------------|---------------|-----|---------------------------------------------|-------------|
| <b>PE_SLEWCTL</b> | GPIO_BA+0x128 | R/W | PE High Slew Rate Control Register          | 0x0000_0000 |
| <b>PE_PUSEL</b>   | GPIO_BA+0x130 | R/W | PE Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>PF_MODE</b>    | GPIO_BA+0x140 | R/W | PF I/O Mode Control                         | 0xXXXX_XXXX |
| <b>PF_DINOFF</b>  | GPIO_BA+0x144 | R/W | PF Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PF_DOUT</b>    | GPIO_BA+0x148 | R/W | PF Data Output Value                        | 0x0000_FFFF |
| <b>PF_DATMSK</b>  | GPIO_BA+0x14C | R/W | PF Data Output Write Mask                   | 0x0000_0000 |
| <b>PF_PIN</b>     | GPIO_BA+0x150 | R   | PF Pin Value                                | 0x0000_XXXX |
| <b>PF_DBEN</b>    | GPIO_BA+0x154 | R/W | PF De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PF_INTTYPE</b> | GPIO_BA+0x158 | R/W | PF Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PF_INTEN</b>   | GPIO_BA+0x15C | R/W | PF Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PF_INTSRC</b>  | GPIO_BA+0x160 | R/W | PF Interrupt Source Flag                    | 0x0000_XXXX |
| <b>PF_SMTEN</b>   | GPIO_BA+0x164 | R/W | PF Input Schmitt Trigger Enable Register    | 0x0000_0000 |
| <b>PF_SLEWCTL</b> | GPIO_BA+0x168 | R/W | PF High Slew Rate Control Register          | 0x0000_0000 |
| <b>PF_PUSEL</b>   | GPIO_BA+0x170 | R/W | PF Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>PG_MODE</b>    | GPIO_BA+0x180 | R/W | PG I/O Mode Control                         | 0xXXXX_XXXX |
| <b>PG_DINOFF</b>  | GPIO_BA+0x184 | R/W | PG Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PG_DOUT</b>    | GPIO_BA+0x188 | R/W | PG Data Output Value                        | 0x0000_1FFF |
| <b>PG_DATMSK</b>  | GPIO_BA+0x18C | R/W | PG Data Output Write Mask                   | 0x0000_0000 |
| <b>PG_PIN</b>     | GPIO_BA+0x190 | R   | PG Pin Value                                | 0x0000_XXXX |
| <b>PG_DBEN</b>    | GPIO_BA+0x194 | R/W | PG De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PG_INTTYPE</b> | GPIO_BA+0x198 | R/W | PG Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PG_INTEN</b>   | GPIO_BA+0x19C | R/W | PG Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PG_INTSRC</b>  | GPIO_BA+0x1A0 | R/W | PG Interrupt Source Flag                    | 0x0000_XXXX |
| <b>PG_SMTEN</b>   | GPIO_BA+0x1A4 | R/W | PG Input Schmitt Trigger Enable Register    | 0x0000_0000 |
| <b>PG_SLEWCTL</b> | GPIO_BA+0x1A8 | R/W | PG High Slew Rate Control Register          | 0x0000_0000 |
| <b>PG_PUSEL</b>   | GPIO_BA+0x1B0 | R/W | PG Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>PH_MODE</b>    | GPIO_BA+0x1C0 | R/W | PH I/O Mode Control                         | 0xXXXX_XXXX |
| <b>PH_DINOFF</b>  | GPIO_BA+0x1C4 | R/W | PH Digital Input Path Disable Control       | 0x0000_0000 |
| <b>PH_DOUT</b>    | GPIO_BA+0x1C8 | R/W | PH Data Output Value                        | 0x0000_1FFF |
| <b>PH_DATMSK</b>  | GPIO_BA+0x1CC | R/W | PH Data Output Write Mask                   | 0x0000_0000 |

|                               |                          |     |                                             |             |
|-------------------------------|--------------------------|-----|---------------------------------------------|-------------|
| <b>PH_PIN</b>                 | GPIO_BA+0x1D0            | R   | PH Pin Value                                | 0x0000_XXXX |
| <b>PH_DBEN</b>                | GPIO_BA+0x1D4            | R/W | PH De-Bounce Enable Control Register        | 0x0000_0000 |
| <b>PH_INTTYPE</b>             | GPIO_BA+0x1D8            | R/W | PH Interrupt Trigger Type Control           | 0x0000_0000 |
| <b>PH_INTEN</b>               | GPIO_BA+0x1DC            | R/W | PH Interrupt Enable Control Register        | 0x0000_0000 |
| <b>PH_INTSRC</b>              | GPIO_BA+0x1E0            | R/W | PH Interrupt Source Flag                    | 0x0000_XXXX |
| <b>PH_SMTEN</b>               | GPIO_BA+0x1E4            | R/W | PH Input Schmitt Trigger Enable Register    | 0x0000_0000 |
| <b>PH_SLEWCTL</b>             | GPIO_BA+0x1E8            | R/W | PH High Slew Rate Control Register          | 0x0000_0000 |
| <b>PH_PUSEL</b>               | GPIO_BA+0x1F0            | R/W | PH Pull-up and Pull-down Selection Register | 0x0000_0000 |
| <b>GPIO_DBCTL</b>             | GPIO_BA+0x440            | R/W | Interrupt De-bounce Control Register        | 0x0000_0020 |
| <b>PAn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x800+(0x04 * n) | R/W | GPIO PA.n Pin Data Input/Output Register    | 0x0000_000X |
| <b>PBn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x840+(0x04 * n) | R/W | GPIO PB.n Pin Data Input/Output Register    | 0x0000_000X |
| <b>PCn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x880+(0x04 * n) | R/W | GPIO PC.n Pin Data Input/Output Register    | 0x0000_000X |
| <b>PDn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x8C0+(0x04 * n) | R/W | GPIO PD.n Pin Data Input/Output Register    | 0x0000_000X |
| <b>PEn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x900+(0x04 * n) | R/W | GPIO PE.n Pin Data Input/Output Register    | 0x0000_000X |
| <b>PFn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x940+(0x04 * n) | R/W | GPIO PF.n Pin Data Input/Output Register    | 0x0000_000X |
| <b>PGn_PDIO<br/>n=0,1..12</b> | GPIO_BA+0x980+(0x04 * n) | R/W | GPIO PG.n Pin Data Input/Output Register    | 0x0000_000X |
| <b>PHn_PDIO<br/>n=0,1..12</b> | GPIO_BA+0x9C0+(0x04 * n) | R/W | GPIO PH.n Pin Data Input/Output Register    | 0x0000_000X |

### 6.5.7 Register Description

#### Port A-H 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 | 0xFFFF_XXXX |
| PB_MODE  | GPIO_BA+0x040 | R/W | PB I/O Mode Control | 0xFFFF_XXXX |
| PC_MODE  | GPIO_BA+0x080 | R/W | PC I/O Mode Control | 0xFFFF_XXXX |
| PD_MODE  | GPIO_BA+0x0C0 | R/W | PD I/O Mode Control | 0xFFFF_XXXX |
| PE_MODE  | GPIO_BA+0x100 | R/W | PE I/O Mode Control | 0xFFFF_XXXX |
| PF_MODE  | GPIO_BA+0x140 | R/W | PF I/O Mode Control | 0xFFFF_XXXX |
| PG_MODE  | GPIO_BA+0x180 | R/W | PG I/O Mode Control | 0xFFFF_XXXX |
| PH_MODE  | GPIO_BA+0x1C0 | R/W | PH I/O Mode Control | 0xFFFF_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 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2n+1:2n]<br>n=0,1..15 | MODEn       | <p><b>Port A-h I/O Pin[n] Mode Control</b></p> <p>Determine each I/O mode of Px.n pins.</p> <p>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.</p> <p><b>Note1:</b> 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 chip powered on.<br/>     If CIOINI is set to 1, the default value is 0x0000_0000 and all pins will be input mode after chip powered on.</p> <p><b>Note2:</b><br/>     Max. n=15 for port A/B/E/G.<br/>     Max. n=14 for port C/D.<br/>     Max. n=11 for port F/H.</p> |

**Port A-H Digital Input Path Disable Control (Px\_DINOFF)**

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



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

Port A-H Data Output Value (Px\_DOUT)

| Register       | Offset        | R/W | Description          | Reset Value |
|----------------|---------------|-----|----------------------|-------------|
| <b>PA_DOUT</b> | GPIO_BA+0x008 | R/W | PA Data Output Value | 0x0000_FFFF |
| <b>PB_DOUT</b> | GPIO_BA+0x048 | R/W | PB Data Output Value | 0x0000_FFFF |
| <b>PC_DOUT</b> | GPIO_BA+0x088 | R/W | PC Data Output Value | 0x0000_FFFF |
| <b>PD_DOUT</b> | GPIO_BA+0x0C8 | R/W | PD Data Output Value | 0x0000_FFFF |
| <b>PE_DOUT</b> | GPIO_BA+0x108 | R/W | PE Data Output Value | 0x0000_FFFF |
| <b>PF_DOUT</b> | GPIO_BA+0x148 | R/W | PF Data Output Value | 0x0000_FFFF |
| <b>PG_DOUT</b> | GPIO_BA+0x188 | R/W | PG Data Output Value | 0x0000_1FFF |
| <b>PH_DOUT</b> | GPIO_BA+0x1C8 | R/W | PH Data Output Value | 0x0000_1FFF |



| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [n]<br>n=0,1..15 | DOUT[n]     | <p><b>Port A-h Pin[n] Output Value</b></p> <p>Each of these bits controls the status of a Px.n pin when the Px.n is configured as Push-pull output, Open-drain output or Quasi-bidirectional mode.</p> <p>0 = Px.n will drive Low if the Px.n pin is configured as Push-pull output, Open-drain output or Quasi-bidirectional mode.</p> <p>1 = Px.n will drive High if the Px.n pin is configured as Push-pull output or Quasi-bidirectional mode.</p> <p><b>Note:</b></p> <p>Max. n=15 for port A/B/E/G.</p> <p>Max. n=14 for port C/D.</p> <p>Max. n=11 for port F/H.</p> |

**Port A-H Data Output Write Mask (Px\_DATMSK)**

| Register  | Offset        | R/W | Description               | Reset Value |
|-----------|---------------|-----|---------------------------|-------------|
| PA_DATMSK | GPIO_BA+0x00C | R/W | PA Data Output Write Mask | 0x0000_0000 |
| PB_DATMSK | GPIO_BA+0x04C | R/W | PB Data Output Write Mask | 0x0000_0000 |
| PC_DATMSK | GPIO_BA+0x08C | R/W | PC Data Output Write Mask | 0x0000_0000 |
| PD_DATMSK | GPIO_BA+0x0CC | R/W | PD Data Output Write Mask | 0x0000_0000 |
| PE_DATMSK | GPIO_BA+0x10C | R/W | PE Data Output Write Mask | 0x0000_0000 |
| PF_DATMSK | GPIO_BA+0x14C | R/W | PF Data Output Write Mask | 0x0000_0000 |
| PG_DATMSK | GPIO_BA+0x18C | R/W | PG Data Output Write Mask | 0x0000_0000 |
| PH_DATMSK | GPIO_BA+0x1CC | R/W | PH Data Output Write Mask | 0x0000_0000 |



| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8]           | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [n]<br>n=0,1..15 | DATMSK[n]   | <p><b>Port A-h Pin[n] Data Output Write Mask</b></p> <p>These bits are used to protect the corresponding DOUT (Px_DOUT[n]) bit. When the DATMSK (Px_DATMSK[n]) bit is set to 1, the corresponding DOUT (Px_DOUT[n]) bit is protected. If the write signal is masked, writing data to the protect bit is ignored.</p> <p>0 = Corresponding DOUT (Px_DOUT[n]) bit can be updated.<br/>1 = Corresponding DOUT (Px_DOUT[n]) bit protected.</p> <p><b>Note1:</b> This function only protects the corresponding DOUT (Px_DOUT[n]) bit, and will not protect the corresponding PDIO (Pxn_PDIO[0]) bit.</p> <p><b>Note2:</b><br/>Max. n=15 for port A/B/E/G.<br/>Max. n=14 for port C/D.<br/>Max. n=11 for port F/H.</p> |

Port A-H Pin Value (Px\_PIN)

| Register | Offset        | R/W | Description  | Reset Value |
|----------|---------------|-----|--------------|-------------|
| PA_PIN   | GPIO_BA+0x010 | R   | PA Pin Value | 0x0000_XXXX |
| PB_PIN   | GPIO_BA+0x050 | R   | PB Pin Value | 0x0000_XXXX |
| PC_PIN   | GPIO_BA+0x090 | R   | PC Pin Value | 0x0000_XXXX |
| PD_PIN   | GPIO_BA+0x0D0 | R   | PD Pin Value | 0x0000_XXXX |
| PE_PIN   | GPIO_BA+0x110 | R   | PE Pin Value | 0x0000_XXXX |
| PF_PIN   | GPIO_BA+0x150 | R   | PF Pin Value | 0x0000_XXXX |
| PG_PIN   | GPIO_BA+0x190 | R   | PG Pin Value | 0x0000_XXXX |
| PH_PIN   | GPIO_BA+0x1D0 | R   | PH Pin Value | 0x0000_XXXX |



| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                          |
| [n]<br>n=0,1..15 | PIN[n]      | <p><b>Port A-h Pin[n] Pin Value</b></p> <p>Each bit of the register reflects the actual status of the respective Px.n pin. If the bit is 1, it indicates the corresponding pin status is high; else the pin status is low.</p> <p><b>Note:</b></p> <ul style="list-style-type: none"> <li>Max. n=15 for port A/B/E/G.</li> <li>Max. n=14 for port C/D.</li> <li>Max. n=11 for port F/H.</li> </ul> |

**Port A-H De-bounce Enable Control Register (Px\_DBEN)**

| Register       | Offset        | R/W | Description                          | Reset Value |
|----------------|---------------|-----|--------------------------------------|-------------|
| <b>PA_DBEN</b> | GPIO_BA+0x014 | R/W | PA De-Bounce Enable Control Register | 0x0000_0000 |
| <b>PB_DBEN</b> | GPIO_BA+0x054 | R/W | PB De-Bounce Enable Control Register | 0x0000_0000 |
| <b>PC_DBEN</b> | GPIO_BA+0x094 | R/W | PC De-Bounce Enable Control Register | 0x0000_0000 |
| <b>PD_DBEN</b> | GPIO_BA+0x0D4 | R/W | PD De-Bounce Enable Control Register | 0x0000_0000 |
| <b>PE_DBEN</b> | GPIO_BA+0x114 | R/W | PE De-Bounce Enable Control Register | 0x0000_0000 |
| <b>PF_DBEN</b> | GPIO_BA+0x154 | R/W | PF De-Bounce Enable Control Register | 0x0000_0000 |
| <b>PG_DBEN</b> | GPIO_BA+0x194 | R/W | PG De-Bounce Enable Control Register | 0x0000_0000 |
| <b>PH_DBEN</b> | GPIO_BA+0x1D4 | R/W | PH De-Bounce Enable Control Register | 0x0000_0000 |



| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [n]<br>n=0,1..15 | DBEN[n]     | <p><b>Port A-h Pin[n] Input Signal De-bounce Enable Bit</b></p> <p>The DBEN[n] bit is used to enable the de-bounce function for each corresponding bit. If the input signal pulse width cannot be sampled by continuous two de-bounce sample cycle, the input signal transition is seen as the signal bounce and will not trigger the interrupt. The de-bounce clock source is controlled by DBCLKSRC (GPIO_DBCTL [4]), one de-bounce sample cycle period is controlled by DBCLKSEL (GPIO_DBCTL [3:0]).</p> <p>0 = Px.n de-bounce function Disabled.<br/>1 = Px.n de-bounce function Enabled.</p> <p>The de-bounce function is valid only for edge triggered interrupt. If the interrupt mode is level triggered, the de-bounce enable bit is ignored.</p> <p><b>Note:</b></p> <ul style="list-style-type: none"> <li>Max. n=15 for port A/B/E/G.</li> <li>Max. n=14 for port C/D.</li> <li>Max. n=11 for port F/H.</li> </ul> |

**Port A-H Interrupt Type Control (Px\_INTTYPE)**

| Register          | Offset        | R/W | Description                       | Reset Value |
|-------------------|---------------|-----|-----------------------------------|-------------|
| <b>PA_INTTYPE</b> | GPIO_BA+0x018 | R/W | PA Interrupt Trigger Type Control | 0x0000_0000 |
| <b>PB_INTTYPE</b> | GPIO_BA+0x058 | R/W | PB Interrupt Trigger Type Control | 0x0000_0000 |
| <b>PC_INTTYPE</b> | GPIO_BA+0x098 | R/W | PC Interrupt Trigger Type Control | 0x0000_0000 |
| <b>PD_INTTYPE</b> | GPIO_BA+0x0D8 | R/W | PD Interrupt Trigger Type Control | 0x0000_0000 |
| <b>PE_INTTYPE</b> | GPIO_BA+0x118 | R/W | PE Interrupt Trigger Type Control | 0x0000_0000 |
| <b>PF_INTTYPE</b> | GPIO_BA+0x158 | R/W | PF Interrupt Trigger Type Control | 0x0000_0000 |
| <b>PG_INTTYPE</b> | GPIO_BA+0x198 | R/W | PG Interrupt Trigger Type Control | 0x0000_0000 |
| <b>PH_INTTYPE</b> | GPIO_BA+0x1D8 | R/W | PH Interrupt Trigger Type Control | 0x0000_0000 |



| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [n]<br>n=0,1..15 | TYPE[n]     | <p><b>Port A-h Pin[n] Edge or Level Detection Interrupt Trigger Type Control</b></p> <p>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.</p> <p>0 = Edge trigger interrupt.<br/>1 = Level trigger interrupt.</p> <p>If the pin is set as the level trigger interrupt, only one level can be set on the registers RHLEN (Px_INTEN[n+16])/FLIEN (Px_INTEN[n]). If both levels to trigger interrupt are set, the setting is ignored and no interrupt will occur.</p> <p>The de-bounce function is valid only for edge triggered interrupt. If the interrupt mode is level triggered, the de-bounce enable bit is ignored.</p> <p><b>Note:</b></p> <ul style="list-style-type: none"> <li>Max. n=15 for port A/B/E/G.</li> <li>Max. n=14 for port C/D.</li> <li>Max. n=11 for port F/H.</li> </ul> |

**Port A-H Interrupt Enable Control Register (Px\_INTEN)**

| Register        | Offset        | R/W | Description                          | Reset Value |
|-----------------|---------------|-----|--------------------------------------|-------------|
| <b>PA_INTEN</b> | GPIO_BA+0x01C | R/W | PA Interrupt Enable Control Register | 0x0000_0000 |
| <b>PB_INTEN</b> | GPIO_BA+0x05C | R/W | PB Interrupt Enable Control Register | 0x0000_0000 |
| <b>PC_INTEN</b> | GPIO_BA+0x09C | R/W | PC Interrupt Enable Control Register | 0x0000_0000 |
| <b>PD_INTEN</b> | GPIO_BA+0x0DC | R/W | PD Interrupt Enable Control Register | 0x0000_0000 |
| <b>PE_INTEN</b> | GPIO_BA+0x11C | R/W | PE Interrupt Enable Control Register | 0x0000_0000 |
| <b>PF_INTEN</b> | GPIO_BA+0x15C | R/W | PF Interrupt Enable Control Register | 0x0000_0000 |
| <b>PG_INTEN</b> | GPIO_BA+0x19C | R/W | PG Interrupt Enable Control Register | 0x0000_0000 |
| <b>PH_INTEN</b> | GPIO_BA+0x1DC | R/W | PH Interrupt Enable Control Register | 0x0000_0000 |



| Bits                | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [n+16]<br>n=0,1..15 | <b>RHIEN[n]</b> | <p><b>Port A-h Pin[n] Rising Edge or High Level Interrupt Trigger Type Enable Bit</b></p> <p>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.</p> <p>When setting the RHIEN (Px_INTEN[n+16]) bit to 1 :</p> <p>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.</p> <p>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.</p> <p>0 = Px.n level high or low to high interrupt Disabled.<br/>1 = Px.n level high or low to high interrupt Enabled.</p> <p><b>Note:</b></p> <p>Max. n=15 for port A/B/E/G.<br/>Max. n=14 for port C/D.<br/>Max. n=11 for port F/H.</p> |
| [n]<br>n=0,1..15    | <b>FLIEN[n]</b> | <p><b>Port A-h Pin[n] Falling Edge or Low Level Interrupt Trigger Type Enable Bit</b></p> <p>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.</p> <p>When setting the FLIEN (Px_INTEN[n]) bit to 1 :</p> <p>If the interrupt is level trigger (TYPE (Px_INTTYPE[n]) bit is set to 1), the input Px.n pin</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <p>will generate the interrupt while this pin state is at low level.</p> <p>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.</p> <p>0 = Px.n level low or high to low interrupt Disabled.</p> <p>1 = Px.n level low or high to low interrupt Enabled.</p> <p><b>Note:</b></p> <p>Max. n=15 for port A/B/E/G.</p> <p>Max. n=14 for port C/D.</p> <p>Max. n=11 for port F/H.</p> |
|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

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

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



| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                      |
| [n]<br>n=0,1..15 | INTSRC[n]   | <p><b>Port A-h Pin[n] Interrupt Source Flag</b></p> <p>Write Operation :</p> <p>0 = No action.</p> <p>1 = Clear the corresponding pending interrupt.</p> <p>Read Operation :</p> <p>0 = No interrupt at Px.n.</p> <p>1 = Px.n generates an interrupt.</p> <p><b>Note:</b></p> <p>Max. n=15 for port A/B/E/G.</p> <p>Max. n=14 for port C/D.</p> <p>Max. n=11 for port F/H.</p> |

**Port A-H Input Schmitt Trigger Enable Register (Px\_SMTEN)**

| Register        | Offset        | R/W | Description                              | Reset Value |
|-----------------|---------------|-----|------------------------------------------|-------------|
| <b>PA_SMTEN</b> | GPIO_BA+0x024 | R/W | PA Input Schmitt Trigger Enable Register | 0x0000_0000 |
| <b>PB_SMTEN</b> | GPIO_BA+0x064 | R/W | PB Input Schmitt Trigger Enable Register | 0x0000_0000 |
| <b>PC_SMTEN</b> | GPIO_BA+0x0A4 | R/W | PC Input Schmitt Trigger Enable Register | 0x0000_0000 |
| <b>PD_SMTEN</b> | GPIO_BA+0x0E4 | R/W | PD Input Schmitt Trigger Enable Register | 0x0000_0000 |
| <b>PE_SMTEN</b> | GPIO_BA+0x124 | R/W | PE Input Schmitt Trigger Enable Register | 0x0000_0000 |
| <b>PF_SMTEN</b> | GPIO_BA+0x164 | R/W | PF Input Schmitt Trigger Enable Register | 0x0000_0000 |
| <b>PG_SMTEN</b> | GPIO_BA+0x1A4 | R/W | PG Input Schmitt Trigger Enable Register | 0x0000_0000 |
| <b>PH_SMTEN</b> | GPIO_BA+0x1E4 | R/W | PH Input Schmitt Trigger Enable Register | 0x0000_0000 |



| Bits             | Description |                                                                                                                                                                                                                                                                       |
|------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                             |
| [n]<br>n=0,1..15 | SMTEN[n]    | <b>Port A-h Pin[n] Input Schmitt Trigger Enable Bit</b><br>0 = Px.n input schmitt trigger function Disabled.<br>1 = Px.n input schmitt trigger function Enabled.<br><b>Note:</b><br>Max. n=15 for port A/B/E/G.<br>Max. n=14 for port C/D.<br>Max. n=11 for port F/H. |

**Port A-H 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 |  | 0x0000_0000 |
| PB_SLEWCTL | GPIO_BA+0x068 | R/W | PB High Slew Rate Control Register |  | 0x0000_0000 |
| PC_SLEWCTL | GPIO_BA+0x0A8 | R/W | PC High Slew Rate Control Register |  | 0x0000_0000 |
| PD_SLEWCTL | GPIO_BA+0x0E8 | R/W | PD High Slew Rate Control Register |  | 0x0000_0000 |
| PE_SLEWCTL | GPIO_BA+0x128 | R/W | PE High Slew Rate Control Register |  | 0x0000_0000 |
| PF_SLEWCTL | GPIO_BA+0x168 | R/W | PF High Slew Rate Control Register |  | 0x0000_0000 |
| PG_SLEWCTL | GPIO_BA+0x1A8 | R/W | PG High Slew Rate Control Register |  | 0x0000_0000 |
| PH_SLEWCTL | GPIO_BA+0x1E8 | R/W | PH High Slew Rate Control Register |  | 0x0000_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  |    | HSREN0  |    |

| Bits                   | Description        |                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2n+1:2n]<br>n=0,1..15 | HSREN <sub>n</sub> | <p><b>Port A-h Pin[n] High Slew Rate Control</b></p> <p>00 = Px.n output with normal slew rate mode (maximum 40 MHz at 2.7V).<br/>     01 = Px.n output with high slew rate mode (maximum 80 MHz at 2.7V).<br/>     10 = Px.n output with fast slew rate mode (maximum 100 MHz at 2.7V).<br/>     11 = Reserved.</p> <p><b>Note:</b></p> <p>Max. n=15 for port A/B/E/G.<br/>     Max. n=14 for port C/D.<br/>     Max. n=11 for port F/H.</p> |

**Port A-H Pull-up and Pull-down Selection Register (Px\_PUSEL)**

| Register        | Offset        | R/W | Description                                 |  | Reset Value |
|-----------------|---------------|-----|---------------------------------------------|--|-------------|
| <b>PA_PUSEL</b> | GPIO_BA+0x030 | R/W | PA Pull-up and Pull-down Selection Register |  | 0x0000_0000 |
| <b>PB_PUSEL</b> | GPIO_BA+0x070 | R/W | PB Pull-up and Pull-down Selection Register |  | 0x0000_0000 |
| <b>PC_PUSEL</b> | GPIO_BA+0x0B0 | R/W | PC Pull-up and Pull-down Selection Register |  | 0x0000_0000 |
| <b>PD_PUSEL</b> | GPIO_BA+0x0F0 | R/W | PD Pull-up and Pull-down Selection Register |  | 0x0000_0000 |
| <b>PE_PUSEL</b> | GPIO_BA+0x130 | R/W | PE Pull-up and Pull-down Selection Register |  | 0x0000_0000 |
| <b>PF_PUSEL</b> | GPIO_BA+0x170 | R/W | PF Pull-up and Pull-down Selection Register |  | 0x0000_0000 |
| <b>PG_PUSEL</b> | GPIO_BA+0x1B0 | R/W | PG Pull-up and Pull-down Selection Register |  | 0x0000_0000 |
| <b>PH_PUSEL</b> | GPIO_BA+0x1F0 | R/W | PH Pull-up and Pull-down Selection Register |  | 0x0000_0000 |

|                |    |                |    |                |    |                |    |
|----------------|----|----------------|----|----------------|----|----------------|----|
| 31             | 30 | 29             | 28 | 27             | 26 | 25             | 24 |
| <b>PUSEL15</b> |    | <b>PUSEL14</b> |    | <b>PUSEL13</b> |    | <b>PUSEL12</b> |    |
| 23             | 22 | 21             | 20 | 19             | 18 | 17             | 16 |
| <b>PUSEL11</b> |    | <b>PUSEL10</b> |    | <b>PUSEL9</b>  |    | <b>PUSEL8</b>  |    |
| 15             | 14 | 13             | 12 | 11             | 10 | 9              | 8  |
| <b>PUSEL7</b>  |    | <b>PUSEL6</b>  |    | <b>PUSEL5</b>  |    | <b>PUSEL4</b>  |    |
| 7              | 6  | 5              | 4  | 3              | 2  | 1              | 0  |
| <b>PUSEL3</b>  |    | <b>PUSEL2</b>  |    | <b>PUSEL1</b>  |    | <b>PUSEL0</b>  |    |

| Bits                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2n+1:2n]<br>n=0,1..15 | <p><b>PUSELn</b></p> <p><b>Port A-h Pin[n] Pull-up and Pull-down Enable Register</b></p> <p>Determine each I/O Pull-up/pull-down of Px.n pins.</p> <p>00 = Px.n pull-up and pull-down disable.<br/>01 = Px.n pull-up enable.<br/>10 = Px.n pull-down enable.</p> <p><b>Note1:</b><br/>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 tri-state and open-drain mode<br/>The independent pull-down control register only valid when MODEn set as tri-state mode<br/>When both pull-up pull-down is set as 1 at “tri-state” mode, keep I/O in tri-state mode</p> <p><b>Note2:</b><br/>Max. n=15 for port A/B/E/G.<br/>Max. n=14 for port C/D.<br/>Max. n=11 for port F/H.</p> |

**Interrupt De-bounce Control Register (GPIO\_DBCTL)**

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

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [5]    | ICLKON      | <p><b>Interrupt Clock on Mode</b></p> <p>0 = Edge detection circuit is active only if I/O pin corresponding RHLEN (Px_INTEN[n+16])/FLIEN (Px_INTEN[n]) bit is set to 1.</p> <p>1 = All I/O pins edge detection circuit is always active after reset.</p> <p><b>Note1:</b> It is recommended to disable this bit to save system power if no special application concern.</p> <p><b>Note2:</b></p> <p>Max. n=15 for port A/B/E/G.</p> <p>Max. n=14 for port C/D.</p> <p>Max. n=11 for port F/H.</p> |
| [4]    | DBCLKSRC    | <p><b>De-bounce Counter Clock Source Selection</b></p> <p>0 = De-bounce counter clock source is the HCLK.</p> <p>1 = De-bounce counter clock source is the 10 kHz internal low speed RC oscillator (LIRC).</p>                                                                                                                                                                                                                                                                                    |

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:0] | <b>DBCLKSEL</b><br><b>De-bounce Sampling Cycle Selection</b><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 |
|-------------------------------|--------------------------|-----|------------------------------------------|-------------|
| <b>PAn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x800+(0x04 * n) | R/W | GPIO PA.n Pin Data Input/Output Register | 0x0000_000X |
| <b>PBn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x840+(0x04 * n) | R/W | GPIO PB.n Pin Data Input/Output Register | 0x0000_000X |
| <b>PCn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x880+(0x04 * n) | R/W | GPIO PC.n Pin Data Input/Output Register | 0x0000_000X |
| <b>PDn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x8C0+(0x04 * n) | R/W | GPIO PD.n Pin Data Input/Output Register | 0x0000_000X |
| <b>PEn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x900+(0x04 * n) | R/W | GPIO PE.n Pin Data Input/Output Register | 0x0000_000X |
| <b>PFn_PDIO<br/>n=0,1..15</b> | GPIO_BA+0x940+(0x04 * n) | R/W | GPIO PF.n Pin Data Input/Output Register | 0x0000_000X |
| <b>PGn_PDIO<br/>n=0,1..12</b> | GPIO_BA+0x980+(0x04 * n) | R/W | GPIO PG.n Pin Data Input/Output Register | 0x0000_000X |
| <b>PHn_PDIO<br/>n=0,1..12</b> | GPIO_BA+0x9C0+(0x04 * n) | R/W | GPIO PH.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        | <p><b>GPIO Px.N Pin Data Input/Output</b><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.</p> <p>Read this register to get GPIO pin status.<br/> For example, writing PA0_PDIO will reflect the written value to bit DOUT (Px_DOUT[0]), reading PA0_PDIO will return the value of PIN (PA_PIN[0]).</p> <p><b>Note1:</b> The writing operation will not be affected by register DATMSK (Px_DATMSK[n]).<br/> <b>Note2:</b><br/> Max. n=15 for port A/B/E/G.</p> |

|  |  |                                                    |
|--|--|----------------------------------------------------|
|  |  | Max. n=14 for port C/D.<br>Max. n=11 for port F/H. |
|--|--|----------------------------------------------------|

## 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 16 channels and each channel can perform transfer between memory and peripherals or between memory and memory.

### 6.6.2 Features

- Supports 16 independently configurable channels
- Selectable 2 level of priority (fixed priority or round-robin priority)
- Supports transfer data width of 8, 16, and 32 bits
- Supports source and destination address increment size can be byte, half-word, word or no increment
- Supports software and SPI, UART, DAC, ADC and PWM request
- Supports Scatter-Gather mode to perform sophisticated transfer through the use of the descriptor link list table
- Supports single and burst transfer type
- Supports time-out function on channel 0 and channel1
- Supports stride function from channel 0 to channel 5

### 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\_AHBCLOCK [1]).

- Reset Configuration
  - Reset PDMA controller in PDMARST (SYS\_IPRST0[2]).

### 6.6.5 Functional Description

The PDMA controller transfers data from one address to another without CPU intervention. The PDMA controller supports 16 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-1.

| PDMA_PRISET | Channel Number | Priority Setting          | Arbitration Priority In Descending Order |
|-------------|----------------|---------------------------|------------------------------------------|
| 1           | 15             | Channel15, Fixed Priority | Highest                                  |

|     |     |                                 |        |
|-----|-----|---------------------------------|--------|
| 1   | 14  | Channel14, Fixed Priority       | ---    |
| --- | --- | ---                             | ---    |
| 1   | 0   | Channel0, Fixed Priority        | ---    |
| 0   | 15  | Channel15, Round-Robin Priority | ---    |
| 0   | 14  | Channel14, Round-Robin Priority | ---    |
| --- | --- | ---                             | ---    |
| 0   | 0   | Channel0, Round-Robin Priority  | Lowest |

Table 6.6-1 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 memory and peripherals, but if user want to transfer data between peripherals and peripherals, one thing must be sure 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[15: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 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[15:0]) flag will be asserted and if this bit is “1” TDIFn will not be active).

If channel 15 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 0x2000\_0000 (only MSB 16 bits valid in PDMA\_SCATBA), the current link address is 0x0000\_0100 (only LSB 16bits without last two bits [1:0] valid in PDMA\_DSCTn\_NEXT), and then the next DSCT entry start address is 0x2000\_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 (PDMA\_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. Please note that, PDMA transfer data between flash and memory should finish before MCU enter idle mode or power done mode to prevent access wrong data

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.



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 setting by corresponding channel's TOUTPSCn (PDMA\_TOUTPSC [2+4n:4n], n=0,1). If time-out counter counts up from 0 to corresponding channel's TOCn (PDMA\_TOCO\_1 [16(n+1)-1:16n], n=0,1), the PDMA controller will generate interrupt signal when corresponding TOUTIENn (PDMA\_TOUTIEN [n], n=0,1) is enabled. When time-out occurred, corresponding channel's REQTOFn (PDMA\_INTSTS [n+8], n=0,1) will be set to indicate channel time-out is happened.

Time-out counter resets to 0 while counter count to TOCn (PDMA\_TOCO\_1 [16(n+1)-1:16n], n=0,1), received trigger signal, time-out function is disabled or chip enters Power-down mode.

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 TOUTEN0(PDMA\_TOUTEN[0]) bit to 1.
2. Time-out counter starts counting from 0 to the value of TOC0(PDMA\_TOCO\_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 from 0 to 5, and user can clear REQTOF0 flag and then poll REQTOF0 flag to check the next time-out occurred.

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 |
|---------------------------------------------|-------------------------|-----|-----------------------------------------------------------------------|-------------|
| <b>PDMA Base Address:</b>                   |                         |     |                                                                       |             |
| PDMA_BA = 0x4000_8000                       |                         |     |                                                                       |             |
| DSCT_CTL_BA = 0x4000_8000                   |                         |     |                                                                       |             |
| DSCT_SA_BA = 0x4000_8004                    |                         |     |                                                                       |             |
| DSCT_DA_BA = 0x4000_8008                    |                         |     |                                                                       |             |
| DSCT_NEXT_BA = 0x4000_800c                  |                         |     |                                                                       |             |
| CURSCAT_BA = 0x4000_8100                    |                         |     |                                                                       |             |
| <b>PDMA_DSCTn_CT<br/>L<br/>n = 0,1..15</b>  | DSCT_CTL_BA + 0x10 * n  | R/W | Descriptor Table Control Register of PDMA Channel n                   | 0xFFFF_FFFF |
| <b>PDMA_DSCTn_SA<br/>n = 0,1..15</b>        | DSCT_SA_BA + 0x10 * n   | R/W | Source Address Register of PDMA Channel n                             | 0xFFFF_FFFF |
| <b>PDMA_DSCTn_DA<br/>n = 0,1..15</b>        | DSCT_DA_BA + 0x10 * n   | R/W | Destination Address Register of PDMA Channel n                        | 0xFFFF_FFFF |
| <b>PDMA_DSCTn_NE<br/>XT<br/>n = 0,1..15</b> | DSCT_NEXT_BA + 0x10 * n | R/W | Next Scatter-Gather Descriptor Table Offset Address of PDMA Channel n | 0xFFFF_FFFF |
| <b>PDMA_CURSCATn<br/>n = 0,1..15</b>        | CURSCAT_BA + 0x004 * n  | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel n     | 0xFFFF_FFFF |
| <b>PDMA_CHCTL</b>                           | PDMA_BA + 0x400         | R/W | PDMA Channel Control Register                                         | 0x0000_0000 |
| <b>PDMA_PAUSE</b>                           | PDMA_BA + 0x404         | W   | PDMA Transfer Pause Control Register                                  | 0x0000_0000 |
| <b>PDMA_SWREQ</b>                           | PDMA_BA + 0x408         | W   | PDMA Software Request Register                                        | 0x0000_0000 |
| <b>PDMA_TRGSTS</b>                          | PDMA_BA + 0x40C         | R   | PDMA Channel Request Status Register                                  | 0x0000_0000 |
| <b>PDMA_PRISET</b>                          | PDMA_BA + 0x410         | R/W | PDMA Fixed Priority Setting Register                                  | 0x0000_0000 |
| <b>PDMA_PRICLR</b>                          | PDMA_BA + 0x414         | W   | PDMA Fixed Priority Clear Register                                    | 0x0000_0000 |
| <b>PDMA_INTEN</b>                           | PDMA_BA + 0x418         | R/W | PDMA Interrupt Enable Register                                        | 0x0000_0000 |
| <b>PDMA_INTSTS</b>                          | PDMA_BA + 0x41C         | R/W | PDMA Interrupt Status Register                                        | 0x0000_0000 |
| <b>PDMA_ABTS</b>                            | PDMA_BA + 0x420         | R/W | PDMA Channel Read/Write Target Abort Flag Register                    | 0x0000_0000 |
| <b>PDMA_TDSTS</b>                           | PDMA_BA + 0x424         | R/W | PDMA Channel Transfer Done Flag Register                              | 0x0000_0000 |
| <b>PDMA_ALIGN</b>                           | PDMA_BA + 0x428         | R/W | PDMA Transfer Alignment Status Register                               | 0x0000_0000 |
| <b>PDMA_TACTSTS</b>                         | PDMA_BA + 0x42C         | R   | PDMA Transfer Active Flag Register                                    | 0x0000_0000 |
| <b>PDMA_TOUTPSC</b>                         | PDMA_BA + 0x430         | R/W | PDMA Time-out Prescaler Register                                      | 0x0000_0000 |
| <b>PDMA_TOUTEN</b>                          | PDMA_BA + 0x434         | R/W | PDMA Time-out Enable Register                                         | 0x0000_0000 |
| <b>PDMA_TOUTIEN</b>                         | PDMA_BA + 0x438         | R/W | PDMA Time-out Interrupt Enable Register                               | 0x0000_0000 |
| <b>PDMA_SCATBA</b>                          | PDMA_BA + 0x43C         | R/W | PDMA Scatter-Gather Descriptor Table Base Address Register            | 0x2000_0000 |

|                         |                 |     |                                                  |             |
|-------------------------|-----------------|-----|--------------------------------------------------|-------------|
| <b>PDMA_TOCO_1</b>      | PDMA_BA + 0x440 | R/W | PDMA Time-out Counter Ch1 and Ch0 Register       | 0xFFFF_FFFF |
| <b>PDMA_CHRST</b>       | PDMA_BA + 0x460 | R/W | PDMA Channel Reset Register                      | 0x0000_0000 |
| <b>PDMA_SPI</b>         | PDMA_BA + 0x464 | R/W | PDMA with SPI Performance Improvement Register   | 0x0000_0000 |
| <b>PDMA_REQSEL0_3</b>   | PDMA_BA + 0x480 | R/W | PDMA Request Source Select Register 0            | 0x0000_0000 |
| <b>PDMA_REQSEL4_7</b>   | PDMA_BA + 0x484 | R/W | PDMA Request Source Select Register 1            | 0x0000_0000 |
| <b>PDMA_REQSEL8_11</b>  | PDMA_BA + 0x488 | R/W | PDMA Request Source Select Register 2            | 0x0000_0000 |
| <b>PDMA_REQSEL12_15</b> | PDMA_BA + 0x48C | R/W | PDMA Request Source Select Register 3            | 0x0000_0000 |
| <b>PDMA_STCR0</b>       | PDMA_BA + 0x500 | R/W | Stride Transfer Count Register of PDMA Channel 0 | 0x0000_0000 |
| <b>PDMA_ASOCR0</b>      | PDMA_BA + 0x504 | R/W | Address Stride Offset Register of PDMA Channel 0 | 0x0000_0000 |
| <b>PDMA_STCR1</b>       | PDMA_BA + 0x508 | R/W | Stride Transfer Count Register of PDMA Channel 1 | 0x0000_0000 |
| <b>PDMA_ASOCR1</b>      | PDMA_BA + 0x50C | R/W | Address Stride Offset Register of PDMA Channel 1 | 0x0000_0000 |
| <b>PDMA_STCR2</b>       | PDMA_BA + 0x510 | R/W | Stride Transfer Count Register of PDMA Channel 2 | 0x0000_0000 |
| <b>PDMA_ASOCR2</b>      | PDMA_BA + 0x514 | R/W | Address Stride Offset Register of PDMA Channel 2 | 0x0000_0000 |
| <b>PDMA_STCR3</b>       | PDMA_BA + 0x518 | R/W | Stride Transfer Count Register of PDMA Channel 3 | 0x0000_0000 |
| <b>PDMA_ASOCR3</b>      | PDMA_BA + 0x51C | R/W | Address Stride Offset Register of PDMA Channel 3 | 0x0000_0000 |
| <b>PDMA_STCR4</b>       | PDMA_BA + 0x520 | R/W | Stride Transfer Count Register of PDMA Channel 4 | 0x0000_0000 |
| <b>PDMA_ASOCR4</b>      | PDMA_BA + 0x524 | R/W | Address Stride Offset Register of PDMA Channel 4 | 0x0000_0000 |
| <b>PDMA_STCR5</b>       | PDMA_BA + 0x528 | R/W | Stride Transfer Count Register of PDMA Channel 5 | 0x0000_0000 |
| <b>PDMA_ASOCR5</b>      | 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 | DSCT_CTL_BA + 0x10 * n | R/W | Descriptor Table Control Register of PDMA Channel n |  |  | 0xXXXX_XXXX |

|          |          |         |    |          |        |        |    |
|----------|----------|---------|----|----------|--------|--------|----|
| 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       | <b>Transfer Count</b><br>The TXCNT represents the required number of PDMA transfer, the real transfer count is (TXCNT + 1); The maximum transfer count is 16384, every transfer may be byte, half-word or word that is dependent on TXWIDTH field.<br><b>Note:</b> When PDMA finish each transfer data, this field will be decrease immediately.                                                                                                              |
| [15]    | STRIDEEN    | <b>Stride Mode Enable Bit</b><br>0 = Stride transfer mode Disabled.<br>1 = Stride transfer mode Enabled.                                                                                                                                                                                                                                                                                                                                                      |
| [14]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [13:12] | TXWIDTH     | <b>Transfer Width Selection</b><br>This field is used for transfer width.<br>00 = One byte (8 bit) is transferred for every operation.<br>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><b>Note:</b> 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       | <b>Destination Address Increment</b><br>This field is used to set the destination address increment size.<br>11 = No increment (fixed address).<br>Others = Increment and size is depended on TXWIDTH selection.                                                                                                                                                                                                                                              |
| [9:8]   | SAINC       | <b>Source Address Increment</b><br>This field is used to set the source address increment size.<br>11 = No increment (fixed address).<br>Others = Increment and size is depended on TXWIDTH selection.                                                                                                                                                                                                                                                        |

| Bits  | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | <b>TBINTDIS</b> | <p><b>Table Interrupt Disable Bit</b></p> <p>This field can be used to decide whether to enable table interrupt or not. If the TBINTDIS bit is enabled it will not generates TDIFn(PDMA_TDSTS[4:0]) when PDMA controller finishes transfer task.</p> <p>0 = Table interrupt Enabled.<br/>1 = Table interrupt Disabled.</p> <p><b>Note:</b> This function only for scatter-gather mode.</p>                                                                                                                                                                                                                                                                                                                                                          |
| [6:4] | <b>BURSIZE</b>  | <p><b>Burst Size</b></p> <p>000 = 128 Transfers.<br/>001 = 64 Transfers.<br/>010 = 32 Transfers.<br/>011 = 16 Transfers.<br/>100 = 8 Transfers.<br/>101 = 4 Transfers.<br/>110 = 2 Transfers.<br/>111 = 1 Transfers.</p> <p><b>Note:</b> This field is only useful in burst transfer type.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [2]   | <b>TXTYPE</b>   | <p><b>Transfer Type</b></p> <p>0 = Burst transfer type.<br/>1 = Single transfer type.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [1:0] | <b>OPMODE</b>   | <p><b>PDMA Operation Mode Selection</b></p> <p>00 = Idle state: Channel is stopped or this table is complete, when PDMA finish channel table task, OPMODE will be cleared to idle state automatically.</p> <p>01 = Basic mode: The descriptor table only has one task. When this task is finished, the PDMA_INTSTS[1] will be asserted.</p> <p>10 = Scatter-Gather mode: When operating in this mode, user must give the next descriptor table address in PDMA_DSCT_NEXT register; PDMA controller will ignore this task, then load the next task to execute.</p> <p>11 = Reserved.</p> <p><b>Note:</b> Before filling new transfer task in the Descriptor Table, user must check the PDMA_INTSTS[1] to make sure the current task is complete.</p> |

**Start Source Address Register (PDMA\_DSCTn\_SA)**

| Register      | Offset                | R/W | Description                               |  |  |  | Reset Value |
|---------------|-----------------------|-----|-------------------------------------------|--|--|--|-------------|
| PDMA_DSCTn_SA | DSCT_SA_BA + 0x10 * n | R/W | Source Address Register of PDMA Channel n |  |  |  | 0xXXXX_XXXX |

|    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|
| 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          | <b>PDMA Transfer Source Address</b><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 | DSCT_DA_BA + 0x10 * n | R/W | Destination Address Register of PDMA Channel n |  |  |  | 0xXXXX_XXXX |

|    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|
| 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          | <b>PDMA Transfer Destination Address</b><br>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 | DSCT_NEXT_BA + 0x10 * n | R/W | Next Scatter-Gather Descriptor Table Offset Address of PDMA Channel n |  |  |  | 0xFFFF_FFFF |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | EXENEXT     | <b>PDMA Execution Next Descriptor Table Offset</b><br>This field indicates the offset of next descriptor table address of current execution descriptor table in system memory.<br><b>Note:</b> write operation is useless in this field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [15:0]  | NEXT        | <b>PDMA Next Descriptor Table Offset</b><br>This field indicates the offset of the next descriptor table address in system memory.<br><b>Write Operation:</b><br>If the system memory based address is 0x2000_0000 (PDMA_SCATBA), and the next descriptor table is start from 0x2000_0100, then this field must fill in 0x0100.<br><b>Read Operation:</b><br>When operating in scatter-gather mode, the last two bits NEXT[1:0] will become reserved, and indicate the first next address of system memory.<br><b>Note1:</b> The descriptor table address must be word boundary.<br><b>Note2:</b> 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 | CURSCAT_BA + 0x004 * n | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel n |  |  |  | 0xFFFF_FFFF |



| Bits   | Description |                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CURADDR     | <p><b>PDMA Current Description Address (Read Only)</b></p> <p>This field indicates a 32-bit current external description address of PDMA controller.</p> <p><b>Note:</b> This field is read only and used for Scatter-Gather mode only to indicate the current external description address.</p> |

**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     |
| CHEN15   | CHEN14 | CHEN13 | CHEN12 | CHEN11 | CHEN10 | CHEN9 | CHEN8 |
| 7        | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
| CHEN7    | CHEN6  | CHEN5  | CHEN4  | CHEN3  | CHEN2  | CHEN1 | CHEN0 |

| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                      |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| [n]<br>n=0,1..15 | CHENN       | <p><b>PDMA Channel Enable Bits</b></p> <p>Set this bit to 1 to enable PDMA<sub>n</sub> operation. Channel cannot be active if it is not set as enabled.</p> <p>0 = PDMA channel [n] Disabled.<br/>1 = PDMA channel [n] Enabled.</p> <p><b>Note:</b> Setting the corresponding bit of PDMA_PAUSE or PDMA_CHRST register will also clear this bit.</p> |

PDMA Transfer Pause Control Register (PDMA\_PAUSE)

| Register   | Offset          | R/W | Description                          |  |  | Reset Value |
|------------|-----------------|-----|--------------------------------------|--|--|-------------|
| PDMA_PAUSE | PDMA_BA + 0x404 | W   | PDMA Transfer Pause Control Register |  |  | 0x0000_0000 |

|          |         |         |         |         |         |        |        |
|----------|---------|---------|---------|---------|---------|--------|--------|
| 31       | 30      | 29      | 28      | 27      | 26      | 25     | 24     |
| Reserved |         |         |         |         |         |        |        |
| 23       | 22      | 21      | 20      | 19      | 18      | 17     | 16     |
| Reserved |         |         |         |         |         |        |        |
| 15       | 14      | 13      | 12      | 11      | 10      | 9      | 8      |
| PAUSE15  | PAUSE14 | PAUSE13 | PAUSE12 | PAUSE11 | PAUSE10 | PAUSE9 | PAUSE8 |
| 7        | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
| PAUSE7   | PAUSE6  | PAUSE5  | PAUSE4  | PAUSE3  | PAUSE2  | PAUSE1 | PAUSE0 |

| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [n]<br>n=0,1..15 | PAUSEn      | <p><b>PDMA Channel N Transfer Pause Control (Write Only)</b></p> <p>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..4) and clear request active flag(PDMA_TRGSTS[n:0], n=0,1..4). If the paused channel is re-enabled again, the remaining transfers will be processed.</p> <p>0 = No effect.<br/>1 = Pause PDMA channel n transfer.</p> |

**PDMA Software Request Register (PDMA\_SWREQ)**

| Register   | Offset          | R/W | Description                    |  |  | Reset Value |
|------------|-----------------|-----|--------------------------------|--|--|-------------|
| PDMA_SWREQ | PDMA_BA + 0x408 | W   | PDMA Software Request Register |  |  | 0x0000_0000 |

|          |         |         |         |         |         |        |        |
|----------|---------|---------|---------|---------|---------|--------|--------|
| 31       | 30      | 29      | 28      | 27      | 26      | 25     | 24     |
| Reserved |         |         |         |         |         |        |        |
| 23       | 22      | 21      | 20      | 19      | 18      | 17     | 16     |
| Reserved |         |         |         |         |         |        |        |
| 15       | 14      | 13      | 12      | 11      | 10      | 9      | 8      |
| SWREQ15  | SWREQ14 | SWREQ13 | SWREQ12 | SWREQ11 | SWREQ10 | SWREQ9 | SWREQ8 |
| 7        | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
| SWREQ7   | SWREQ6  | SWREQ5  | SWREQ4  | SWREQ3  | SWREQ2  | SWREQ1 | SWREQ0 |

| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [n]<br>n=0,1..15 | SWREQn      | <p><b>PDMA Software Request (Write Only)</b></p> <p>Set this bit to 1 to generate a software request to PDMA [n].</p> <p>0 = No effect.</p> <p>1 = Generate a software request.</p> <p><b>Note1:</b> User can read PDMA_TRGSTS register to know which channel is on active. Active flag may be triggered by software request or peripheral request.</p> <p><b>Note2:</b> If user does not enable corresponding PDMA channel, the software request will be ignored.</p> |

**PDMA Channel Request Status Register (PDMA\_TRGSTS)**

| Register    | Offset          | R/W | Description                          |  |  |  | Reset Value |
|-------------|-----------------|-----|--------------------------------------|--|--|--|-------------|
| PDMA_TRGSTS | PDMA_BA + 0x40C | R   | PDMA Channel Request Status Register |  |  |  | 0x0000_0000 |

|          |          |          |          |          |          |         |         |
|----------|----------|----------|----------|----------|----------|---------|---------|
| 31       | 30       | 29       | 28       | 27       | 26       | 25      | 24      |
| Reserved |          |          |          |          |          |         |         |
| 23       | 22       | 21       | 20       | 19       | 18       | 17      | 16      |
| Reserved |          |          |          |          |          |         |         |
| 15       | 14       | 13       | 12       | 11       | 10       | 9       | 8       |
| REQSTS15 | REQSTS14 | REQSTS13 | REQSTS12 | REQSTS11 | REQSTS10 | REQSTS9 | REQSTS8 |
| 7        | 6        | 5        | 4        | 3        | 2        | 1       | 0       |
| REQSTS7  | REQSTS6  | REQSTS5  | REQSTS4  | REQSTS3  | REQSTS2  | REQSTS1 | REQSTS0 |

| Bits             | Description         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved            | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [n]<br>n=0,1..15 | REQSTS <sub>n</sub> | <p><b>PDMA Channel Request Status (Read Only)</b></p> <p>This flag indicates whether channel[n] have a request or not, no matter request from software or peripheral. When PDMA controller finishes channel transfer, this bit will be cleared automatically.</p> <p>0 = PDMA Channel n has no request.<br/>1 = PDMA Channel n has a request.</p> <p><b>Note:</b> If user pauses or resets each PDMA transfer by setting PDMA_PAUSE or PDMA_CHRST register respectively, this bit will be cleared automatically after finishing the current transfer.</p> |

**PDMA Fixed Priority Setting Register (PDMA\_PRISET)**

| Register    | Offset          | R/W | Description                          |  |  | Reset Value |
|-------------|-----------------|-----|--------------------------------------|--|--|-------------|
| PDMA_PRISET | PDMA_BA + 0x410 | R/W | PDMA Fixed Priority Setting Register |  |  | 0x0000_0000 |

|           |           |           |           |           |           |          |          |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|
| 31        | 30        | 29        | 28        | 27        | 26        | 25       | 24       |
| Reserved  |           |           |           |           |           |          |          |
| 23        | 22        | 21        | 20        | 19        | 18        | 17       | 16       |
| Reserved  |           |           |           |           |           |          |          |
| 15        | 14        | 13        | 12        | 11        | 10        | 9        | 8        |
| FPRISET15 | FPRISET14 | FPRISET13 | FPRISET12 | FPRISET11 | FPRISET10 | FPRISET9 | FPRISET8 |
| 7         | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| FPRISET7  | FPRISET6  | FPRISET5  | FPRISET4  | FPRISET3  | FPRISET2  | FPRISET1 | FPRISET0 |

| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [n]<br>n=0,1..15 | FPRISETn    | <p><b>PDMA Fixed Priority Setting</b><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/> <b>Note:</b> This field only set to fixed priority, clear fixed priority use PDMA_PRICLR register.</p> |

**PDMA Fix Priority Clear Register (PDMA\_PRICLR)**

| Register    | Offset          | R/W | Description                        |  |  | Reset Value |
|-------------|-----------------|-----|------------------------------------|--|--|-------------|
| PDMA_PRICLR | PDMA_BA + 0x414 | W   | PDMA Fixed Priority Clear Register |  |  | 0x0000_0000 |

|           |           |           |           |           |           |          |          |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|
| 31        | 30        | 29        | 28        | 27        | 26        | 25       | 24       |
| Reserved  |           |           |           |           |           |          |          |
| 23        | 22        | 21        | 20        | 19        | 18        | 17       | 16       |
| Reserved  |           |           |           |           |           |          |          |
| 15        | 14        | 13        | 12        | 11        | 10        | 9        | 8        |
| FPRICLR15 | FPRICLR14 | FPRICLR13 | FPRICLR12 | FPRICLR11 | FPRICLR10 | FPRICLR9 | FPRICLR8 |
| 7         | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| FPRICLR7  | FPRICLR6  | FPRICLR5  | FPRICLR4  | FPRICLR3  | FPRICLR2  | FPRICLR1 | FPRICLR0 |

| Bits              | Description |                                                                                                                                                                                                                                                                                        |
|-------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]           | Reserved    | Reserved.                                                                                                                                                                                                                                                                              |
| [n]<br>n=0..1..15 | FPRICLRn    | <p><b>PDMA Fixed Priority Clear Bits (Write Only)</b></p> <p>Set this bit to 1 to clear fixed priority level.</p> <p>0 = No effect.</p> <p>1 = Clear PDMA channel [n] fixed priority setting.</p> <p><b>Note:</b> User can read PDMA_PRISET register to know the channel priority.</p> |

**PDMA Interrupt Enable Register (PDMA\_INTEN)**

| Register   | Offset          | R/W | Description                    |  |  | Reset Value |
|------------|-----------------|-----|--------------------------------|--|--|-------------|
| PDMA_INTEN | PDMA_BA + 0x418 | R/W | PDMA Interrupt Enable Register |  |  | 0x0000_0000 |

|          |         |         |         |         |         |        |        |
|----------|---------|---------|---------|---------|---------|--------|--------|
| 31       | 30      | 29      | 28      | 27      | 26      | 25     | 24     |
| Reserved |         |         |         |         |         |        |        |
| 23       | 22      | 21      | 20      | 19      | 18      | 17     | 16     |
| Reserved |         |         |         |         |         |        |        |
| 15       | 14      | 13      | 12      | 11      | 10      | 9      | 8      |
| INTEN15  | INTEN14 | INTEN13 | INTEN12 | INTEN11 | INTEN10 | INTEN9 | INTEN8 |
| 7        | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
| INTEN7   | INTEN6  | INTEN5  | INTEN4  | INTEN3  | INTEN2  | INTEN1 | INTEN0 |

| Bits             | Description |                                                                                                                                                                                                                                                                                     |
|------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                           |
| [n]<br>n=0,1..15 | INTENn      | <p><b>PDMA Interrupt Enable Bits</b></p> <p>This field is used to enable PDMA channel[n] interrupt.</p> <p>0 = PDMA channel n interrupt Disabled.<br/>1 = PDMA channel n interrupt Enabled.</p> <p><b>Note:</b> The interrupt flag is time-out, abort, transfer done and align.</p> |

**PDMA Interrupt Status Register (PDMA\_INTSTS)**

| Register    | Offset          | R/W | Description                    |  |  |  | Reset Value |
|-------------|-----------------|-----|--------------------------------|--|--|--|-------------|
| PDMA_INTSTS | PDMA_BA + 0x41C | R/W | PDMA Interrupt Status Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                               |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                     |
| [9]     | REQTOF1     | <b>Request Time-out Flag for Channel 1</b><br>This flag indicates that PDMA controller has waited peripheral request for a period defined by PDMA_TOC1, user can write 1 to clear these bits.<br>0 = No request time-out.<br>1 = Peripheral request time-out.                                 |
| [8]     | REQTOF0     | <b>Request Time-out Flag for Channel 0</b><br>This flag indicates that PDMA controller has waited peripheral request for a period defined by PDMA_TOC0, user can write 1 to clear these bits.<br>0 = No request time-out.<br>1 = Peripheral request time-out.                                 |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                     |
| [2]     | ALIGNF      | <b>Transfer Alignment Interrupt Flag (Read Only)</b><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        | <b>Transfer Done Interrupt Flag (Read Only)</b><br>This bit indicates that PDMA controller has finished transmission; User can read PDMA_TDSTS register to indicate which channel finished transfer.<br>0 = Not finished yet.<br>1 = PDMA channel has finished transmission.                  |
| [0]     | ABTIF       | <b>PDMA Read/Write Target Abort Interrupt Flag (Read Only)</b><br>This bit indicates that PDMA has target abort error; Software can read PDMA_ABSTS register to find which channel has target abort error.<br>0 = No AHB bus ERROR response received.<br>1 = AHB bus ERROR response received. |

**PDMA Channel Read/Write Target Abort Flag Register (PDMA\_ABSTS)**

| Register   | Offset          | R/W | Description                                        |  |  |  | Reset Value |
|------------|-----------------|-----|----------------------------------------------------|--|--|--|-------------|
| PDMA_ABSTS | PDMA_BA + 0x420 | R/W | PDMA Channel Read/Write Target Abort 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      |
| ABTIF15  | ABTIF14 | ABTIF13 | ABTIF12 | ABTIF11 | ABTIF10 | ABTIF9 | ABTIF8 |
| 7        | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
| ABTIF7   | ABTIF6  | ABTIF5  | ABTIF4  | ABTIF3  | ABTIF2  | ABTIF1 | ABTIF0 |

| Bits             | Description |                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [n]<br>n=0,1..15 | ABTIFn      | <p><b>PDMA Read/Write Target Abort Interrupt Status Flag</b></p> <p>This bit indicates which PDMA controller has target abort error; User can write 1 to clear these bits.</p> <p>0 = No AHB bus ERROR response received when channel n transfer.<br/>1 = AHB bus ERROR response received when channel n transfer.</p> <p><b>Note:</b> If channel n target abort, REQSRCn should set 0 to disable peripheral request.</p> |

**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     |
| TDIF15   | TDIF14 | TDIF13 | TDIF12 | TDIF11 | TDIF10 | TDIF9 | TDIF8 |
| 7        | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
| TDIF7    | TDIF6  | TDIF5  | TDIF4  | TDIF3  | TDIF2  | TDIF1 | TDIF0 |

| Bits             | Description |                                                                                                                                                                                                                                                                           |
|------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |
| [n]<br>n=0,1..15 | TDIFn       | <p><b>Transfer Done Flag</b></p> <p>This bit indicates whether PDMA controller channel transfer has been finished or not, user can write 1 to clear these bits.</p> <p>0 = PDMA channel transfer has not finished.</p> <p>1 = PDMA channel has finished transmission.</p> |

**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 |  |  |  | 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      |
| ALIGN15  | ALIGN14 | ALIGN13 | ALIGN12 | ALIGN11 | ALIGN10 | ALIGN9 | ALIGN8 |
| 7        | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
| ALIGN7   | ALIGN6  | ALIGN5  | ALIGN4  | ALIGN3  | ALIGN2  | ALIGN1 | ALIGN0 |

| Bits             | Description |                                                                                                                                                                                                                                                                                                                              |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                    |
| [n]<br>n=0,1..15 | ALIGNn      | <p><b>Transfer Alignment Flag</b></p> <p>0 = PDMA channel source address and destination address both follow transfer width setting.</p> <p>1 = PDMA channel source address or destination address is not follow transfer width setting.</p> <p><b>Note:</b> Source address and destination address should be alignment.</p> |

**PDMA Transfer Active Flag Register (PDMA\_TACTSTS)**

| Register     | Offset          | R/W | Description                        |  |  | Reset Value |
|--------------|-----------------|-----|------------------------------------|--|--|-------------|
| PDMA_TACTSTS | PDMA_BA + 0x42C | R   | PDMA Transfer Active Flag Register |  |  | 0x0000_0000 |

|          |          |          |          |          |          |         |         |
|----------|----------|----------|----------|----------|----------|---------|---------|
| 31       | 30       | 29       | 28       | 27       | 26       | 25      | 24      |
| Reserved |          |          |          |          |          |         |         |
| 23       | 22       | 21       | 20       | 19       | 18       | 17      | 16      |
| Reserved |          |          |          |          |          |         |         |
| 15       | 14       | 13       | 12       | 11       | 10       | 9       | 8       |
| TXACTF15 | TXACTF14 | TXACTF13 | TXACTF12 | TXACTF11 | TXACTF10 | TXACTF9 | TXACTF8 |
| 7        | 6        | 5        | 4        | 3        | 2        | 1       | 0       |
| TXACTF7  | TXACTF6  | TXACTF5  | TXACTF4  | TXACTF3  | TXACTF2  | TXACTF1 | TXACTF0 |

| Bits             | Description |                                                                                                                                                                                          |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]          | Reserved    | Reserved.                                                                                                                                                                                |
| [n]<br>n=0,1..15 | TXACTFn     | <p><b>Transfer on Active Flag (Read Only)</b></p> <p>This bit indicates which PDMA channel is in active.</p> <p>0 = PDMA channel is not finished.</p> <p>1 = PDMA channel is active.</p> |

## PDMA Time-out Prescaler Register (PDMA\_TOUTPSC)

| Register     | Offset          | R/W | Description                      |  |  |  | Reset Value |
|--------------|-----------------|-----|----------------------------------|--|--|--|-------------|
| PDMA_TOUTPSC | PDMA_BA + 0x430 | R/W | PDMA Time-out Prescaler 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 | TOUTPSC1 |    |    | Reserved | TOUTPSC0 |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [6:4]  | TOUTPSC1    | <b>PDMA Channel 1 Time-out Clock Source Prescaler Bits</b><br>000 = PDMA channel 1 time-out clock source is HCLK/2 <sup>8</sup> .<br>001 = PDMA channel 1 time-out clock source is HCLK/2 <sup>9</sup> .<br>010 = PDMA channel 1 time-out clock source is HCLK/2 <sup>10</sup> .<br>011 = PDMA channel 1 time-out clock source is HCLK/2 <sup>11</sup> .<br>100 = PDMA channel 1 time-out clock source is HCLK/2 <sup>12</sup> .<br>101 = PDMA channel 1 time-out clock source is HCLK/2 <sup>13</sup> .<br>110 = PDMA channel 1 time-out clock source is HCLK/2 <sup>14</sup> .<br>111 = PDMA channel 1 time-out clock source is HCLK/2 <sup>15</sup> . |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [2:0]  | TOUTPSC0    | <b>PDMA Channel 0 Time-out Clock Source Prescaler Bits</b><br>000 = PDMA channel 0 time-out clock source is HCLK/2 <sup>8</sup> .<br>001 = PDMA channel 0 time-out clock source is HCLK/2 <sup>9</sup> .<br>010 = PDMA channel 0 time-out clock source is HCLK/2 <sup>10</sup> .<br>011 = PDMA channel 0 time-out clock source is HCLK/2 <sup>11</sup> .<br>100 = PDMA channel 0 time-out clock source is HCLK/2 <sup>12</sup> .<br>101 = PDMA channel 0 time-out clock source is HCLK/2 <sup>13</sup> .<br>110 = PDMA channel 0 time-out clock source is HCLK/2 <sup>14</sup> .<br>111 = PDMA channel 0 time-out clock source is HCLK/2 <sup>15</sup> . |

**PDMA Time-out Enable Register (PDMA\_TOUTEN)**

| Register    | Offset          | R/W | Description                   |  |  |  | Reset Value |
|-------------|-----------------|-----|-------------------------------|--|--|--|-------------|
| PDMA_TOUTEN | PDMA_BA + 0x434 | R/W | PDMA Time-out Enable Register |  |  |  | 0x0000_0000 |

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

| Bits         | Description |                                                                                                                                     |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| [31:2]       | Reserved    | Reserved.                                                                                                                           |
| [n]<br>n=0,1 | TOUTENn     | <b>PDMA Time-out Enable Bits</b><br>0 = PDMA Channel n time-out function Disabled.<br>1 = PDMA Channel n time-out function Enabled. |

**PDMA Time-out Interrupt Enable Register (PDMA\_TOUTIEN)**

| Register     | Offset          | R/W | Description                             |  |  |  | Reset Value |
|--------------|-----------------|-----|-----------------------------------------|--|--|--|-------------|
| PDMA_TOUTIEN | PDMA_BA + 0x438 | R/W | PDMA Time-out Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits         | Description |                                                                                                                                                 |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2]       | Reserved    | Reserved.                                                                                                                                       |
| [n]<br>n=0,1 | TOUTIENn    | <b>PDMA Time-out Interrupt Enable Bits</b><br>0 = PDMA Channel n time-out interrupt Disabled.<br>1 = PDMA Channel n time-out interrupt Enabled. |

**PDMA Scatter-gather Descriptor Table Base Address Register (PDMA\_SCATBA)**

| Register    | Offset          | R/W | Description                                                |  |  |  | Reset Value |
|-------------|-----------------|-----|------------------------------------------------------------|--|--|--|-------------|
| PDMA_SCATBA | PDMA_BA + 0x43C | R/W | PDMA Scatter-Gather Descriptor Table Base Address Register |  |  |  | 0x2000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | SCATBA      | <b>PDMA Scatter-gather Descriptor Table Address</b><br>In Scatter-Gather mode, this is the base address for calculating the next link - list address. The next link address equation is<br>$\text{Next Link Address} = \text{PDMA\_SCATBA} + \text{PDMA\_DSCT\_NEXT}$ .<br><b>Note:</b> 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  |
| TOC0 |    |    |    |    |    |    |    |
| 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| TOC0 |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | TOC1        | <b>Time-out Counter for Channel 1</b><br>This controls the period of time-out function for channel 1. The calculation unit is based on TOUTPSC1 (PDMA_TOUTPSC[5:3]) clock. The example of time-out period can refer TOC0 bit description.            |
| [15:0]  | TOC0        | <b>Time-out Counter for Channel 0</b><br>This controls the period of time-out function for channel 0. The calculation unit is based on TOUTPSC0 (PDMA_TOUTPSC[2:0]) clock.<br>Time-out period = (Period of time-out clock) * (16-bit TOCn), n = 0,1. |

**PDMA Channel Reset Register (PDMA\_CHRST)**

| Register   | Offset          | R/W | Description                 |  |  | Reset Value |
|------------|-----------------|-----|-----------------------------|--|--|-------------|
| PDMA_CHRST | PDMA_BA + 0x460 | R/W | PDMA Channel Reset 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      |
| CH15RST  | CH14RST | CH13RST | CH12RST | CH11RST | CH10RST | CH9RST | CH8RST |
| 7        | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
| CH7RST   | CH6RST  | CH5RST  | CH4RST  | CH3RST  | CH2RST  | CH1RST | CH0RST |

| Bits    | Description |                                                                                                              |
|---------|-------------|--------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                    |
| [15:0]  | CHnRST      | <b>Channel N Reset</b><br>0 = corresponding channel n is not reset.<br>1 = corresponding channel n is reset. |

**PDMA Request Source Select Register 0 (PDMA\_REQSEL0\_3)**

| Register       | Offset          | R/W | Description                           |  |  |  | Reset Value |
|----------------|-----------------|-----|---------------------------------------|--|--|--|-------------|
| PDMA_REQSEL0_3 | PDMA_BA + 0x480 | R/W | PDMA Request Source Select Register 0 |  |  |  | 0x0000_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     | <p><b>Channel 3 Request Source Selection</b></p> <p>This field defines which peripheral is connected to PDMA channel 3. User can configure the peripheral setting by REQSRC3.</p> <p><b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p>                                                                         |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                         |
| [22:16] | REQSRC2     | <p><b>Channel 2 Request Source Selection</b></p> <p>This field defines which peripheral is connected to PDMA channel 2. User can configure the peripheral setting by REQSRC2.</p> <p><b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p>                                                                         |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                         |
| [14:8]  | REQSRC1     | <p><b>Channel 1 Request Source Selection</b></p> <p>This field defines which peripheral is connected to PDMA channel 1. User can configure the peripheral setting by REQSRC1.</p> <p><b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p>                                                                         |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                         |
| [6:0]   | REQSRC0     | <p><b>Channel 0 Request Source Selection</b></p> <p>This field defines which peripheral is connected to PDMA channel 0. User can configure the peripheral by setting REQSRC0.</p> <p>0 = Disable PDMA peripheral request.<br/>     1 = Reserved.<br/>     2 = Channel connects to USB_TX.<br/>     3 = Channel connects to USB_RX.<br/>     4 = Channel connects to UART0_TX.</p> |

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 5 = Channel connects to UART0_RX.<br>6 = Channel connects to UART1_TX.<br>7 = Channel connects to UART1_RX.<br>8 = Channel connects to UART2_TX.<br>9 = Channel connects to UART2_RX.<br>10=Channel connects to UART3_TX.<br>11 = Channel connects to UART3_RX.<br>12 = Channel connects to UART4_TX.<br>13 = Channel connects to UART4_RX.<br>14 = Channel connects to UART5_TX.<br>15 = Channel connects to UART5_RX.<br>16 = Channel connects to USCI0_TX.<br>17 = Channel connects to USCI0_RX.<br>18 = Channel connects to USCI1_TX.<br>19 = Channel connects to USCI1_RX.<br>20 = Channel connects to QSPI0_TX.<br>21 = Channel connects to QSPI0_RX.<br>22 = Channel connects to SPI0_TX.<br>23 = Channel connects to SPI0_RX.<br>24 = Channel connects to SPI1_TX.<br>25 = Channel connects to SPI1_RX.<br>26 = Channel connects to SPI2_TX.<br>27 = Channel connects to SPI2_RX.<br>28 = Channel connects to SPI3_TX.<br>29 = Channel connects to SPI3_RX.<br>30 = Reserved.<br>31 = Reserved.<br>32 = Channel connects to EPWM0_P1_RX.<br>33 = Channel connects to EPWM0_P2_RX.<br>34 = Channel connects to EPWM0_P3_RX.<br>35 = Channel connects to EPWM1_P1_RX.<br>36 = Channel connects to EPWM1_P2_RX.<br>37 = Channel connects to EPWM1_P3_RX.<br>38 = Channel connects to I2C0_TX.<br>39 = Channel connects to I2C0_RX.<br>40 = Channel connects to I2C1_TX.<br>41 = Channel connects to I2C1_RX.<br>42 = Channel connects to I2C2_TX.<br>43 = Channel connects to I2C2_RX.<br>44 = Channel connects to I2S0_TX.<br>45 = Channel connects to I2S0_RX.<br>46 = Channel connects to TMR0.<br>47 = Channel connects to TMR1.<br>48 = Channel connects to TMR2.<br>49 = Channel connects to TMR3.<br>50 = Channel connects to ADC_RX.<br>51 = Channel connects to DAC0_TX.<br>52 = Channel connects to DAC1_TX. |

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <p>53 = Channel connects to EPWM0_CH0_TX.<br/>     54 = Channel connects to EPWM0_CH1_TX.<br/>     55 = Channel connects to EPWM0_CH2_TX.<br/>     56 = Channel connects to EPWM0_CH3_TX.<br/>     57 = Channel connects to EPWM0_CH4_TX.<br/>     58 = Channel connects to EPWM0_CH5_TX.<br/>     59 = Channel connects to EPWM1_CH0_TX.<br/>     60 = Channel connects to EPWM1_CH1_TX.<br/>     61 = Channel connects to EPWM1_CH2_TX.<br/>     62 = Channel connects to EPWM1_CH3_TX.<br/>     63 = Channel connects to EPWM1_CH4_TX.<br/>     64 = Channel connects to EPWM1_CH5_TX.<br/>     65 = Channel connects to ETMC_RX.<br/>     Others = Reserved.</p> <p><b>Note 1:</b> A peripheral cannot be assigned to two channels at the same time.<br/> <b>Note 2:</b> This field is useless when transfer between memory and memory.</p> |

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     | <b>Channel 7 Request Source Selection</b><br>This field defines which peripheral is connected to PDMA channel 7. User can configure the peripheral setting by REQSRC7.<br><b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0. |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                  |
| [22:16] | REQSRC6     | <b>Channel 6 Request Source Selection</b><br>This field defines which peripheral is connected to PDMA channel 6. User can configure the peripheral setting by REQSRC6.<br><b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0. |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                  |
| [14:8]  | REQSRC5     | <b>Channel 5 Request Source Selection</b><br>This field defines which peripheral is connected to PDMA channel 5. User can configure the peripheral setting by REQSRC5.<br><b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0. |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                  |
| [6:0]   | REQSRC4     | <b>Channel 4 Request Source Selection</b><br>This field defines which peripheral is connected to PDMA channel 4. User can configure the peripheral setting by REQSRC4.<br><b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0. |

**PDMA Request Source Select Register 2 (PDMA\_REQSEL8\_11)**

| Register        | Offset          | R/W | Description                           |  |  |  | Reset Value |
|-----------------|-----------------|-----|---------------------------------------|--|--|--|-------------|
| PDMA_REQSEL8_11 | PDMA_BA + 0x488 | R/W | PDMA Request Source Select Register 2 |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [30:24] | REQSRC11    | <p><b>Channel 11 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 11. User can configure the peripheral setting by REQSRC11.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p> |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [22:16] | REQSRC10    | <p><b>Channel 10 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 10. User can configure the peripheral setting by REQSRC10.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p> |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [14:8]  | REQSRC9     | <p><b>Channel 9 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 9. User can configure the peripheral setting by REQSRC9.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p>    |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [6:0]   | REQSRC8     | <p><b>Channel 8 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 8. User can configure the peripheral setting by REQSRC8.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p>    |

**PDMA Request Source Select Register 3 (PDMA\_REQSEL12\_15)**

| Register         | Offset          | R/W | Description                           |  |  |  | Reset Value |
|------------------|-----------------|-----|---------------------------------------|--|--|--|-------------|
| PDMA_REQSEL12_15 | PDMA_BA + 0x48C | R/W | PDMA Request Source Select Register 3 |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [30:24] | REQSRC15    | <p><b>Channel 15 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 15. User can configure the peripheral setting by REQSRC15.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p> |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [22:16] | REQSRC14    | <p><b>Channel 14 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 14. User can configure the peripheral setting by REQSRC14.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p> |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [14:8]  | REQSRC13    | <p><b>Channel 13 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 13. User can configure the peripheral setting by REQSRC13.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p> |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |
| [6:0]   | REQSRC12    | <p><b>Channel 12 Request Source Selection</b><br/> This field defines which peripheral is connected to PDMA channel 12. User can configure the peripheral setting by REQSRC12.<br/> <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</p> |

**PDMA Stride Transfer Count Register n (PDMA\_STCRn)**

| Register          | Offset          | R/W | Description                                      |  |  | Reset Value |
|-------------------|-----------------|-----|--------------------------------------------------|--|--|-------------|
| <b>PDMA_STCR0</b> | PDMA_BA + 0x500 | R/W | Stride Transfer Count Register of PDMA Channel 0 |  |  | 0x0000_0000 |
| <b>PDMA_STCR1</b> | PDMA_BA + 0x508 | R/W | Stride Transfer Count Register of PDMA Channel 1 |  |  | 0x0000_0000 |
| <b>PDMA_STCR2</b> | PDMA_BA + 0x510 | R/W | Stride Transfer Count Register of PDMA Channel 2 |  |  | 0x0000_0000 |
| <b>PDMA_STCR3</b> | PDMA_BA + 0x518 | R/W | Stride Transfer Count Register of PDMA Channel 3 |  |  | 0x0000_0000 |
| <b>PDMA_STCR4</b> | PDMA_BA + 0x520 | R/W | Stride Transfer Count Register of PDMA Channel 4 |  |  | 0x0000_0000 |
| <b>PDMA_STCR5</b> | PDMA_BA + 0x528 | R/W | Stride Transfer Count Register of PDMA Channel 5 |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                               |
| [15:0]  | STC         | <b>PDMA Stride Transfer Count</b><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 | 0x0000_0000 |
| PDMA_ASOCR1 | PDMA_BA + 0x50C | R/W | Address Stride Offset Register of PDMA Channel 1 | 0x0000_0000 |
| PDMA_ASOCR2 | PDMA_BA + 0x514 | R/W | Address Stride Offset Register of PDMA Channel 2 | 0x0000_0000 |
| PDMA_ASOCR3 | PDMA_BA + 0x51C | R/W | Address Stride Offset Register of PDMA Channel 3 | 0x0000_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 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                       |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | DASOL       | <b>VDMA Destination Address Stride Offset Length</b><br>The 16-bit register defines the destination address stride transfer offset count of each row. |
| [15:0]  | SASOL       | <b>VDMA Source Address Stride Offset Length</b><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 two PWM output channels in independent mode and complementary mode. The output state of PWM output pin can be controlled by pin mask, polarity and break control, and dead-time generator.

### 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 event for interval measurement
- Supports external capture pin event to reset 24-bit up counter
- Supports chip wake-up from Idle/Power-down mode if a timer interrupt signal is generated
- Supports Timer0 ~ Timer3 time-out interrupt signal or capture interrupt signal to trigger EPWM, 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

#### 6.7.2.2 PWM Function Features

- Supports maximum clock frequency up to maximum PCLK
- Supports independent mode for PWM generator with two output channels
- Supports complementary mode for PWM generator with paired PWM output channel
  - 12-bit dead-time insertion with 12-bit prescale
- Supports 12-bit prescale from 1 to 4096
- Supports 16-bit PWM counter
  - Up, down and up-down count operation type
  - One-shot or auto-reload counter operation mode
- Supports mask function and tri-state enable for each PWM output pin
- Supports brake function
  - Brake source from pin, analog comparator and system safety events (clock failed,

- Brown-out detection, SRAM parity error and CPU lockup)
- Brake pin noise filter control for brake source
- Edge detect brake source to control brake state until brake status cleared
- Level detect brake source to auto recover function after brake condition removed
- Supports interrupt on the following events:
  - PWM zero point, period point, up-count compared or down-count compared point events
  - Brake condition happened
- Supports trigger EADC on the following events:
  - PWM zero point, period, zero or period point, up-count compared or down-count compared point events

### 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 FUNMODE (TIMERx\_ALTCTL[0]) 0 to enable timer mode. The clock source of Timer0 ~ Timer3 in timer mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]) and selected as different frequency in TMR0SEL (CLK\_CLKSEL1[10:8]) for Timer0, TMR1SEL (CLK\_CLKSEL1[14:12]) for Timer1, TMR2SEL (CLK\_CLKSEL1[18:16]) for Timer2 and TMR3SEL (CLK\_CLKSEL1[22:20]) for Timer3 as Figure 6.7-2.



Figure 6.7-2 Clock Source of Timer Controller



Figure 6.7-3 PWM Generator Overview Block Diagram

Set FUNMODE (TIMERx\_ALTCTL[0]) 1 to enable PWM mode. The clock source of Timer0 ~ Timer3 in PWM mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]). TMR0\_CLK and TMR1\_CLK clock sources are fixed to PCLK0. TMR2\_CLK and TMR3\_CLK clock sources are fixed to PCLK1. PWM system clock frequency will be PCLKx frequency as Figure 6.7-4 .

The clock source of PWM counter (TIMERx\_PWMCLK) can be selected from PWM system clock (TMRx\_CLK) or Timer interrupt events (TMRx\_INT) as Figure 6.7-5.



Figure 6.7-4 PWM System Clock Source Control



Figure 6.7-5 PWM Counter Clock Source Control

Figure 6.7-6 and Figure 6.7-7 illustrate the architecture of PWM independent mode and complementary mode. Both independent mode and complementary mode supports PWM<sub>x</sub>\_CH0 and PWM<sub>x</sub>\_CH1 output channels in each PWM generator.

When counter counts to 0, PERIOD (TIMER<sub>x</sub>\_PWMPERIOD[15:0]) or equal to CMP (TIMER<sub>x</sub>\_PWMCMPDAT[15:0]), relative events will be generated. These events are passed to corresponding generators to generate PWM pulse (Pulse Generator), interrupt signal (Interrupt Generator) and trigger signal (Trigger Generator) for ADC to start conversion. Output Control block is used to decide PWM pulse output; brake function in Output Control block also generates interrupt events. And Dead-Time Control is available only in PWM complementary mode.



Figure 6.7-6 PWM Independent Mode Architecture Diagram



Figure 6.7-7 PWM Complementary Mode Architecture Diagram

#### 6.7.4 Basic Configuration

Set FUNMODE (TMRx\_ALTCTL[0]) 0 to enable timer mode. The clock source of Timer0 ~ Timer3 in timer mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]) and selected as different frequency in TMR0SEL (CLK\_CLKSEL1[10:8]) for Timer0, TMR1SEL (CLK\_CLKSEL1[14:12]) for Timer1, TMR2SEL (CLK\_CLKSEL1[18:16]) for Timer2 and TMR3SEL (CLK\_CLKSEL1[22:20]) for Timer3.

Set FUNMODE (TMRx\_ALTCTL[0]) 1 to enable PWM mode. The clock source of Timer0 ~ Timer3 in PWM mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]). TMR0\_CLK and TMR1\_CLK clock sources are fixed to PCLK0. TMR2\_CLK and TMR3\_CLK clock sources are fixed to PCLK1.

##### 6.7.4.1 TIMER01 basic configurations

- Clock source Configuration
  - Enable TIMER0 peripheral clock in TMR0CKEN (CLK\_APBCLK0[2]).
  - Enable TIMER1 peripheral clock in TMR1CKEN (CLK\_APBCLK0[3]).
- Reset Configuration
  - Reset TIMER0 controller in TMR0RST (SYS\_IPRST2[2]).
  - Reset TIMER0 controller in TMR1RST (SYS\_IPRST2[3]).
- Pin configuration

| Group | Pin Name | GPIO               | MFP   |
|-------|----------|--------------------|-------|
| TM0   | TM0      | PG.2               | MFP13 |
|       |          | PB.5, PC.7         | MFP14 |
|       | TM0_EXT  | PA.11, PB.15, PH.0 | MFP13 |
| TM1   | TM1      | PC.14, PG.3        | MFP13 |
|       |          | PB.4, PC.6         | MFP14 |
|       | TM1_EXT  | PA.10, PB.14, PH.1 | MFP13 |

Table 6.7-1 TIMER01 Pin Configuration

#### 6.7.4.2 TIMER23 basic configurations

- Clock source Configuration
  - Enable TIMER2 peripheral clock in TMR2CKEN (CLK\_APBCLK0[4]).
  - Enable TIMER3 peripheral clock in TMR2CKEN (CLK\_APBCLK0[5]).
- Reset Configuration
  - Reset TIMER2 controller in TMR2RST (SYS\_IPRST2[4]).
  - Reset TIMER3 controller in TMR3RST (SYS\_IPRST2[5]).
- Pin configuration

| Group | Pin Name | GPIO              | MFP   |
|-------|----------|-------------------|-------|
| TM2   | TM2      | PG.4              | MFP13 |
|       |          | PA.7, PB.3, PD.0  | MFP14 |
|       | TM2_EXT  | PA.9, PB.13, PH.2 | MFP13 |
| TM3   | TM3      | PF.11             | MFP13 |
|       |          | PA.6, PB.2        | MFP14 |
|       | TM3_EXT  | PA.8, PB.12, PH.3 | MFP13 |

Table 6.7-2 TIMER23 Pin Configuration

#### 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 associated CAPEdge (TIMERx\_EXTCTL[14:12]) setting. The TWKF (TIMERx\_INTSTS[1]) bit indicates the interrupt wake-up flag status of timer. 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:

##### 6.7.5.3 One-shot Mode

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

User can monitor the counter reset operation active by RSTACT (TIMERx\_CNT[31]). And set ICEDEBUG (TIMERx\_CTL[31]) to 1 that disable ICE debug mode acknowledgement effects TIMER counting.

##### 6.7.5.4 Periodic Mode

If the timer controller is configured at periodic mode (TIMERx\_CTL[28:27] is 01) and CNTEN (TIMERx\_CTL[30]) is set, the timer counter starts up counting. Once the CNT (TIMERx\_CNT[23:0]) value reaches CMPDAT (TIMERx\_CMP[23:0]) value, the TIF (TIMERx\_INTSTS[0]) will be set to 1, CNT value will be cleared automatically by timer controller and timer counter operates counting again.

In the meantime, if the INTEN (TIMERx\_CTL[29]) bit is enabled, the timer interrupt signal is generated and sent to NVIC to inform CPU also. In this mode, 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 at periodic mode.

#### 6.7.5.5 Toggle-Output Mode

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

#### 6.7.5.6 Continuous Counting Mode

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

For example, CMPDAT value is set as 80, first. The TIF will set to 1 when CNT value is equal to 80, timer counter is kept counting and CNT value will not goes back to 0, it continues to count 81, 82, 83, ... to 224 -1, 0, 1, 2, 3, ... to 224 -1 again and again. Next, if user programs CMPDAT value as 200 and clears TIF, the TIF will set to 1 again when CNT value reaches to 200. At last, user programs CMPDAT as 500 and clears TIF, the TIF will set to 1 again when CNT value reaches to 500.

In this mode, the timer counting is continuous. So, this operation mode is called as continuous counting mode.



Figure 6.7-8 Continuous Counting Mode

#### 6.7.5.7 Event Counting Mode

The timer controller also provides an application which can count the input event from TMx (x= 0~3)

pin and the number of event will reflect to CNT (TIMERx\_CNT[23:0]) value. It is also called as event counting function. In this function, EXTCNTEN (TIMERx\_CTL[24]) should be set and the timer peripheral clock source should be set as PCLK.

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

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.8 External Capture Mode

The event capture function is used to load CNT (TIMERx\_CNT[23:0]) value to CAPDAT (TIMERx\_CAP[23:0]) value while edge transition detected on TMx\_EXT (x= 0~3) pin. 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.

Users can enable CAPIEN (TIMERx\_EXTCTL[5]) to use capture interrupt fuction. When the TMx\_EXT edge transition meets setting, CAPIF is high.

Users must consider the Timer will keep register TIMERx\_CAP unchanged and drop the new capture value, if the CPU does not clear the CAPIF status.



Figure 6.7-9 External Capture Mode

If CAPSRC (TIMERx\_CTL[22]) is 1, the capture event can be triggered by internal output signal transition on ACMP0 if ACMPSSEL (TIMERx\_EXTCTL[8]) is 0, or ACMP1 if ACMPSSEL (TIMERx\_EXTCTL[8]) is 1.

#### 6.7.5.9 External 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 as 1 for select TMx\_EXT transition or internal ACMPx output signal to trigger reset counter value.



Figure 6.7-10 External Reset Counter Mode

#### 6.7.5.10 Timer Trigger Function

The timer controller provides timer time-out interrupt or capture interrupt to trigger EPWM, ADC, DAC and PDMA. If TRGSSEL (TIMERx\_TRGCTL[0]) is 0, time-out interrupt signal is used to trigger EPWM, ADC, DAC and PDMA. If TRGSSEL (TIMERx\_TRGCTL[0]) is 1, capture interrupt signal is used to trigger EPWM, ADC, 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 EPWM external clock source.

When the TRGADC (TIMERx\_TRGCTL[2]) is set, if the timer interrupt signal is generated, the timer controller will trigger ADC to start 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-11 Internal Timer Trigger

#### 6.7.5.11 Inter-Timer Trigger Capture Mode

In this mode, the Timer0/2 will be forced in event counting mode, counting with external event, and will generate an internal signal (INTR\_TMR\_TRG) to trigger Timer1/3 start or stop counting. Also, the Timer1/3 will be forced in capture mode and start/stop trigger-counting by Timer0/2 counter status.

Setting Timer0 Inter-timer Trigger Capture enabled, trigger-counting capture function is forced on Timer1. Setting Timer2 Inter-Timer Trigger enabled, trigger-counting capture function is forced on Timer3.

#### Start Trigger

While INTRGEN (TIMERx\_CTL[19]) in Timer0/2 is set, the Timer0/2 will make a rising-edge transition of INTR\_TMR\_TRG while Timer0/2 24-bit counter value (CNT) is counting from 0x0 to 0x1 and Timer1/3 counter will start counting immediately and automatically.

### Stop Trigger

When Timer0/2 CNT reaches the Timer0/2 CMPDAT value, the Timer0/2 will make a falling-edge transition of INTR\_TMR\_TRG. Then Timer0/2 counter mode function will be disabled and INTRGEN (TIMERx\_CTL[19]) will be cleared by hardware then Timer1/3 will stop counting also. At the same time, the Timer1/3 CNT value will be saved into Timer1/3 CAPDAT (TIMERx\_CAP[23:0]).

User can use inter-timer trigger mode to measure the period of external event (TMx) more precisely. Figure 6.7-12 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-12 Inter-Timer Trigger Capture Timing

### 6.7.6 PWM Functional Description

#### 6.7.6.1 PWM Prescale

The PWM prescale is used to divide clock source, and the clock of PWM counter is divided by (CLKPSC + 1). The prescale is set by CLKPSC (TIMERx\_PWMCLKPSC[11:0]). Figure 6.7-13 shows an example of PWM prescale waveform in up count type.



Figure 6.7-13 PWM Prescale Waveform in Up Count Type

### 6.7.6.2 PWM Counter

The PWM supports three counter types operation: up count, down count and up-down count types.

#### 6.7.6.3 Up Count Type

When PWM counter is set to up count type, CNTTYPE (TIMERx\_PWMCTL[2:1]) is 0x0, 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 zero point event when both counter and prescale counts to 0. PWM generates a period point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.7-14 shows an example of PWM up count type, where PWM period time is (PERIOD+1) \* (CLKPSC+1) \* TMRx\_PWMCLK.



Figure 6.7-14 PWM Up Count Type

#### 6.7.6.4 Down Count Type

When PWM counter is set to down count type, CNTTYPE (TIMERx\_PWMCTL[2:1]) is 0x1, it starts down-counting from PERIOD to 0, current counter value can be read from CNT (TIMERx\_PWMCNT[15:0]). PWM generates a zero point event when both counter and prescale counts to 0. PWM generates a period point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.7-15 is an example of PWM down count type, where PWM period time is (PERIOD+1) \* (CLKPSC+1) \* TMRx\_PWMCLK.



Figure 6.7-15 PWM Down Count Type

### 6.7.6.5 Up-Down Count Type

When PWM counter is set to up-down count type, CNTTYPE (TIMERx\_PWMCTL[2:1]) is 0x2, it starts counting up from 0 to PERIOD and then starts counting down to 0. The current counter value can be read from CNT (TIMERx\_PWMCNT[15:0]). PWM generates a zero point event when both counter and prescale counts to 0. PWM generates a center point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.7-16 shows an example of PWM up-down count type, where PWM period time is  $(2 * \text{PERIOD}) * (\text{CLKPSC}+1) * \text{TMRx\_PWMCLK}$ . The DIRF (TIMERx\_PWMCNT[16]) is counter direction indicator flag, where 1 is up counting, and 0 is down counting.



Figure 6.7-16 PWM Up-Down Count Type

### 6.7.6.6 PWM Counter Operation mode

The PWM counter supports two operation modes: one-shot mode and auto-reload mode. PWM counter will operate in one-shot mode if CNTMODE (TIMERx\_PWMCTL[3]) bit is set to 1, and operate in auto-reload mode if CNTMODE bit is set to 0.

In both modes, CMP (TIMERx\_PWMCMPPDAT[15:0]) and PERIOD (TIMERx\_PWMPPERIOD[15:0]) should be written first and then set CNTEN (TIMERx\_PWMCTL[0]) bit to 1 to start counter running.

In one-shot mode, PWM counter value will reload to default value according count type after one PWM period is completed. User can write CMP to continuous one-shot operation to generate next one-shot pulse once no matter current one-shot counter is running or completed.

In auto-reload mode, PWM counter is continuous running with current active PERIOD and CMP. If user sets PERIOD to zero in auto-reload mode, PWM counter value will reload to default value according count type after one PWM period is completed.

### 6.7.6.7 PWM Comparator

The CMP (TIMERx\_PWMCMPPDAT[15:0]) is comparator register of PWM. The CMP value is continuously compared to the corresponding counter value. When the counter is equal to CMP, PWM generates a compared point event. This event will generate PWM output pulse, interrupt signal or trigger ADC start convert. In up-down count type, two events will be generated in a PWM period as shown in Figure 6.7-17. The CMPPU is up count compared point event and CMPPD is down count

compared point event.



Figure 6.7-17 PWM Comparator Events in Up-Down Count Type

#### 6.7.6.8 Period Loading Mode

When the IMMLDEN (TIMERx\_PWMCTL[9]) bit set to 0, PWM operates at period loading mode. The PWM provides PBUF (TIMERx\_PWPMPBUF[15:0]) is the active PERIOD buffer register and CMPBUF (TIMERx\_PWMCPMBUF[15:0]) is the active CMP buffer register. In period loading mode, both PERIOD (TIMERx\_PWMPPERIOD[15:0]) and CMP (TIMERx\_PWMCPMDAT[15:0]) will load to their active PBUF and CMPBU register while each PWM period is completed. Figure 6.7-18 shows period loading timing of up count type, where PERIOD DATA0 denotes the initial data of PERIOD, PERIOD DATA1 denotes the first updated PERIOD data by user and so on, CMP also follows this rule. The following steps are the sequence of Figure 6.7-18.

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-18 Period Loading Mode with Up Count Type

#### 6.7.6.9 Immediately Loading Mode

When the IMMLDEN (TIMERx\_PWMCTL[9]) bit is set to 1, PWM operates at immediately loading mode. In immediately loading mode, when user update PERIOD (TIMERx\_PWMPERIOD[15:0]) or CMP (TIMERx\_PWMCMPPDAT[15:0]), PERIOD or CMP will be load to active PBUF (TIMERx\_PWMMPBUF[15:0]) or CMPBUF (TIMERx\_PWMCMPPBUF[15:0]) after current counter count is completed. If the update PERIOD value is less than current counter value, counter will count wraparound. The following steps are the sequence of Figure 6.7-19.

1. User writes CMP DATA1 at point 1 and hardware will load CMP DATA1 to CMPBUF after current counter count is completed.
2. User writes PERIOD DATA1 at point 2 and PERIOD DATA1 is greater than current counter value, PWM counter will continuously count until equal to PERIOD DATA1 to complete one PWM period.
3. User writes PERIOD DATA2 at point 3 and PERIOD DATA2 is less than the current counter value, PWM counter will continuously count to maximum counter value 0xFFFF and wraparound from 0x10000 to PERIOD DATA2 to complete one PWM period.



Figure 6.7-19 Immediately Loading Mode with Up Count Type

#### 6.7.6.10 PWM Pulse Generator

PWM pulse generator uses counter and comparator events to generate PWM output pulse. The events are zero point and period point in up count type and down count type, center point in up-down count type and counter equal to comparator point in three count types.

Each event point can generate PWM output waveform in different count type as shown in Figure 6.7-20, Figure 6.7-21 and Figure 6.7-22.



Figure 6.7-20 PWM Pulse Generation in Up-Down Count Type



Figure 6.7-21 PWM Pulse Generation in Up Count Type



Figure 6.7-22 PWM Pulse Generation in Down Count Type

The PWM generation events may sometimes be generated at the same time, as the reason, events priority between different counter types should be take care are listed in Table 6.7-3, Table 6.7-4 and Table 6.7-5, event priority in up count type, event priority in down count type and event priority in up-down count type.

| Priority | Zero And CMPU Point Event<br>( $CMP = 0$ ) | PWM Output |
|----------|--------------------------------------------|------------|
| 1 (High) | Compare up event                           | Low        |
| 2 (Low)  | Zero event                                 | High       |

Table 6.7-3 PWM Pulse Generation Event Priority in Up Count Type

| Priority | Zero And CMPD Point Event<br>( $CMP = 0$ )        | PWM Output |
|----------|---------------------------------------------------|------------|
| 1 (High) | Zero event                                        | Low        |
| 2 (Low)  | Compare down event                                | High       |
| Priority | Period and CMPD point event<br>( $CMP = PERIOD$ ) | PWM output |

|          |                    |      |
|----------|--------------------|------|
| 1 (High) | Compare down event | High |
| 2 (Low)  | Period event       | Low  |

Table 6.7-4 PWM Pulse Generation Event Priority in Down Count Type

| Priority | CMPU And CMPU Point Event<br>(CMP = PERIOD) | PWM Output |
|----------|---------------------------------------------|------------|
| 1 (High) | Compare down event                          | High       |
| 2 (Low)  | Compare up event                            | Low        |

Table 6.7-5 PWM Pulse Generation Event Priority in Up-Down Count Type

According to event priority limitation, PWM generator can support 0% and 100% duty cycle PWM output waveform only in up count and up-down count type. Figure 6.7-23 is an example about PWM duty cycle from 0% to 100% in up count type and up-down count type where PERIOD is 4 with different CMP value.



Figure 6.7-23 PWM 0% to 100% Duty Cycle in Up Count Type and Up-Down Count Type

#### 6.7.6.11 PWM Output Mode

The PWM supports two output modes: independent mode which may be applied to DC motor system, complementary mode with dead-time insertion which may be used in the application of AC induction motor and permanent magnet synchronous motor.

#### 6.7.6.12 Independent Mode

When OUTMODE (TIMERx\_PWMCTL[16]) bit is set to 0, PWM output operates in independent mode. In this mode, both PWMx\_CH0 and PWMx\_CH1 can output the same waveform as shown in Figure 6.7-24.



Figure 6.7-24 PWM Independent Mode Output Waveform

#### 6.7.6.13 Complementary Mode

When OUTMODE (TIMERx\_PWMCTL[16]) bit is set to 1, PWM output operates in complementary mode. In this mode, both PWMx\_CH0 and PWMx\_CH1 can output waveform and PWMx\_CH1 must always be the complement of PWMx\_CH0 as shown in Figure 6.7-25.



Figure 6.7-25 PWM Complementary Mode Output Waveform

#### 6.7.6.14 PWM Output Control

After PWM pulse generator, there are four steps to control output waveform in independent output mode and five control steps in complementary output mode. User can set POEN0 (TIMERx\_PWMPOEN[0]) and POEN1 (TIMERx\_PWMPOEN[1]) 1 to enable PWMx\_CH0 and PWMx\_CH1 output waveform.

In Independent mode, there are mask control, brake control, polarity control and output enable control to control output waveform as shown in Figure 6.7-26.



Figure 6.7-26 PWMx\_CH0 Output Control in Independent Mode

In complementary mode, there are dead-time insertion control and four control steps the same as independent mode to control PWMx\_CH0 and PWMx\_CH1 outputs as shown in Figure 6.7-27.



Figure 6.7-27 PWMx\_CH0 and PWMx\_CH1 Output Control in Complementary Mode

### 6.7.6.15 Dead-Time Insertion Control

In the complementary application, the complementary channels may drive the external devices like power switches. The dead-time generator inserts a low level interval between complementary outputs PWMx\_CH0 and PWMx\_CH1 as shown in Figure 6.7-28. User sets DTEN (TIMERx\_PWMDTCTL[16]) bit to enable dead-time control function, DTCNT (TIMERx\_PWMDTCTL[11:0]) and DTCKSEL (TIMERx\_PWMDTCTL[24]) to control dead-time interval. The dead-time interval can be calculated from the following formula:

Dead-time interval = (DTCNT + 1) \* TMRx\_PWMCLK period, if DTCKSEL is 0

Dead-time interval = (DTCNT + 1) \* TMRx\_PWMCLK \* (CLKPSC + 1) period, if DTCKSEL is 1



Figure 6.7-28 Dead-Time Insertion

### 6.7.6.16 PWM Mask Output Control

PWMx\_CH0/CH1 output value can be masked to specified logic states by setting MSKEN0/1 (TIMERx\_PWMMSKEN[1:0]) and MSKDAT0/1 (TIMERx\_PWMMSK[1:0]). The PWM output mask function is useful when controlling various types of Electrically Commutated Motor (ECM) like a BLDC motor. Figure 6.7-29 shows an example of PWM output mask control in PWMx\_CH0 and PWMx\_CH1.



Figure 6.7-29 PWM Output Mask Control Waveform

### 6.7.6.17 PWM Brake Control

Each PWM generator supports one external input brake pin as PWM brake event source. User can select active brake pin source in BKPINSRC (TIMERx\_PWBKF[17:16]), PWMx\_BRAKEy (y=0,1 and y=0,1). There is a 3-bit noise filter counter to filter the external brake pin signal. User can enable BRKNFEN (TIMERx\_PWBKF[0]) to enable the brake pin noise filter function and the noise filter

sampling clock can be selected by setting BRKNFSEL (TIMERx\_PWMBNF[3:1]) to fit different noise properties. Moreover, by setting BRKFCNT (TIMERx\_PWMBNF[6:4]), user can define by how many sampling clock cycles a filter will recognize the effective edge of the brake pin signal. In addition, brake pin polar can be inversed by setting BRKPINV (TIMERx\_PWMBNF[7]) to realize the polarity setup for the brake control signals. Set BRKPINV to 0, brake event will occurred when PWM<sub>x</sub>\_BRAKE<sub>x</sub> pin status from low to high; set BRKPINV to 1, brake event will occurred when PWM<sub>x</sub>\_BRAKE<sub>x</sub> pin status from high to low.



Figure 6.7-30 Brake Pin Noise Filter Block Diagram

User can set BRKAEVEN (TIMERx\_PWMRKCTL[17:16]) for PWM<sub>x</sub>\_CH0 output state and BRKAODD (TIMERx\_PWMRKCTL[19:18]) for PWM<sub>x</sub>\_CH1 output state when PWM brake event happened. There are two brake detector sources, edge detect brake source and level detect brake source when brake event happened. Figure 6.7-31 shows the brake event block diagram for PWM<sub>x</sub>\_CH0 and PWM<sub>x</sub>\_CH1.



Figure 6.7-31 Brake Event Block Diagram for PWMx\_CH0 and PWMx\_CH1

When the edge detector detects the brake signal, the brake function generates interrupt status for PWMx\_CH1/0 is BRKEIF1/0 (TIMERx\_PWMINTSTS1[1:0]) and brake event status for PWMx\_CH1/0 is BRKESTS1/0 (TIMERx\_PWMINTSTS1[17:16]). The interrupt status BRKEIF1/0 can be cleared by writing 1 to it, and the brake event status BRKESTS1/0 will keep until the next PWM period starts when corresponding BRKEIF1/0 flag has been cleared and PWM generator can resume normal output.

Figure 6.7-32 shows an example of edge detector brake waveform for PWMx\_CH0 and PWMx\_CH1. In this case, the edge detect brake source has occurred twice for the brake events. When the first brake event occurs, both of the BRKEIF0 and BRKEIF1 flags are set and BRKESTS0 and BRKESTS1 status are also set to indicate brake state of PWMx\_CH0 and PWMx\_CH1. For the first occurring event, user writes 1 to clear the BRKEIF0. After that, the BRKESTS0 is cleared by hardware at the next start of the PWM period and the PWMx\_CH0 outputs the normal waveform even though the edge brake event is still occurring. At the same time, BRKESTS1 keep 1 and PWMx\_CH1 keep outputs low in brake state. The second event also triggers the same flags, but at this time, user writes 1 to clear the BRKEIF1. Afterward, PWMx\_CH1 outputs normally at the next start of the PWM period.



Figure 6.7-32 Edge Detector Brake Waveform for PWMx\_CH0 and PWMx\_CH1

When the level detector detects the brake signal, the brake function generates interrupt status for PWMx\_CH1/0 is BRKLIF1/0 (TIMERx\_PWMINTSTS1[9:8]) and brake event status for PWMx\_CH1/0 is BRKLSTS1/0 (TIMERx\_PWMINTSTS1[25:24]). The interrupt status BRKLIF1/0 can be cleared by writing 1 to it, and the brake event status BRKLSTS1/0 will be cleared only when current period is completed and brake condition removed, then PWM generator can resume normal output when next PWM period starts.

Figure 6.7-33 shows an example of level detector brake waveform for PWMx\_CH0 and PWMx\_CH1. In this case, the BRKLIF0 and BRKLIF1 can only indicate the brake event has occurred, writes 1 to clear this flags will not affect BRKLSTS0 and BRKLSTS1 brake event status. Both BRKLSTS0 and BRKLSTS1 brake states will automatically cleared at the start of the next PWM period when level brake condition has released no matter BRKLIF0 and BRKLIF1 status.



Figure 6.7-33 Level Detector Brake Waveform for PWMx\_CH0 and PWMx\_CH1

The two kinds of detectors detect the same five brake sources as shown in Figure 6.7-34: one from PWM<sub>x</sub>\_BRAKEy (x=0,1 and y=0,1) external input signals, two from internal ACMP comparator signals, one from system fail events and one from software trigger brake event. ACMP brake sources will be detected only when internal ACMP0\_O or ACMP1\_O signal from low to high.



Figure 6.7-34 Brake Source Block Diagram

Among the above described brake sources, the brake source coming from system fail event can be specified to one of the different system fail conditions, these conditions include clock fail, BOD detect, SRAM parity error and CPU lockup as shown in Figure 6.7-35.



Figure 6.7-35 System Fail Brake Block Diagram

### 6.7.6.18 Polarity Control

Each PWMx\_CH0 and PWMx\_CH1 has an independent polarity control to configure the polarity of the active state of PWM output. User can control polarity state of PWMx\_CH0 on PINV0 (TIMERx\_PWMPOLCTL[0]) and PWMx\_CH1 on PINV1 (TIMERx\_PWMPOLCTL[1]). Figure 6.7-36 shows the PWMx\_CH0 and PWMx\_CH1 output with polarity control and dead-time insertion.



Figure 6.7-36 PWMx\_CH0 and PWMx\_CH1 Polarity Control with Dead-Time Insertion

### 6.7.6.19 PWM Interrupt Generator

There are independent interrupts for each PWM as shown in Figure 6.7-37.

The PWM interrupt (PWMx\_INT) comes from PWM complementary pair events. The counter can generate the zero point interrupt flag ZIF (TIMERx\_PWMINTSTS0[0]) and the period point interrupt flag PIF (TIMERx\_PWMINTSTS0[1]). When counter equals to the comparator value stored in CMP (TIMERx\_PWMCMPPDAT[15:0]), the different interrupt flags will be triggered depending on the counting direction. If counter and CMP matched occurs at up-count direction, the comparator up interrupt flag CMPIUF (TIMERx\_PWMINTSTS0[2]) is set and if matched at down-count direction, the comparator down interrupt flag CMPDIF (TIMERx\_PWMINTSTS0[3]) is set. If the corresponding interrupt enable bits are set, the interrupt trigger events will also generates interrupt signals. When PWM brake event occurred, the relatives interrupt event will be triggered according to PWM brake settings.



Figure 6.7-37 PWM Interrupt Architecture Diagram

#### 6.7.6.20 PWM Trigger ADC Generator

PWM counter event can be one of the ADC conversion trigger source. User sets **TRGSEL (TIMERx\_PWMADCTS[3:0])** to select which PWM counter event can trigger ADC conversion after **TRGEN (TIMERx\_PWMADCTS [7])** is enabled.

There are five PWM counter events can be selected as the trigger source to start ADC conversion as shown in Figure 6.7-38.



Figure 6.7-38 PWM Trigger ADC Block Diagram

### 6.7.7 Register Map

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

| Register                      | Offset        | R/W | Description                                   | Reset Value |
|-------------------------------|---------------|-----|-----------------------------------------------|-------------|
| <b>TIMER Base Address:</b>    |               |     |                                               |             |
| <b>TMR01_BA = 0x4005_0000</b> |               |     |                                               |             |
| <b>TMR23_BA = 0x4005_1000</b> |               |     |                                               |             |
| <b>TIMER0_CTL</b>             | TMR01_BA+0x00 | R/W | Timer0 Control Register                       | 0x0000_0005 |
| <b>TIMER0_CMP</b>             | TMR01_BA+0x04 | R/W | Timer0 Comparator Register                    | 0x0000_0000 |
| <b>TIMER0_INTS_TS</b>         | TMR01_BA+0x08 | R/W | Timer0 Interrupt Status Register              | 0x0000_0000 |
| <b>TIMER0_CNT</b>             | TMR01_BA+0x0C | R/W | Timer0 Data Register                          | 0x0000_0000 |
| <b>TIMER0_CAP</b>             | TMR01_BA+0x10 | R   | Timer0 Capture Data Register                  | 0x0000_0000 |
| <b>TIMER0_EXT_CTL</b>         | TMR01_BA+0x14 | R/W | Timer0 External Control Register              | 0x0000_0000 |
| <b>TIMER0_EINT_STS</b>        | TMR01_BA+0x18 | R/W | Timer0 External Interrupt Status Register     | 0x0000_0000 |
| <b>TIMER0_TRG_CTL</b>         | TMR01_BA+0x1C | R/W | Timer0 Trigger Control Register               | 0x0000_0000 |
| <b>TIMER0_ALT_CTL</b>         | TMR01_BA+0x20 | R/W | Timer0 Alternative Control Register           | 0x0000_0000 |
| <b>TIMER0_PWM_CTL</b>         | TMR01_BA+0x40 | R/W | Timer0 PWM Control Register                   | 0x0000_0000 |
| <b>TIMER0_PWM_CLKSRC</b>      | TMR01_BA+0x44 | R/W | Timer0 PWM Counter Clock Source Register      | 0x0000_0000 |
| <b>TIMER0_PWM_CLKPSC</b>      | TMR01_BA+0x48 | R/W | Timer0 PWM Counter Clock Pre-scale Register   | 0x0000_0000 |
| <b>TIMER0_PWM_CNTCLR</b>      | TMR01_BA+0x4C | R/W | Timer0 PWM Clear Counter Register             | 0x0000_0000 |
| <b>TIMER0_PWM_PERIOD</b>      | TMR01_BA+0x50 | R/W | Timer0 PWM Period Register                    | 0x0000_0000 |
| <b>TIMER0_PWM_CMPDAT</b>      | TMR01_BA+0x54 | R/W | Timer0 PWM Comparator Register                | 0x0000_0000 |
| <b>TIMER0_PWM_DTCTL</b>       | TMR01_BA+0x58 | R/W | Timer0 PWM Dead-Time Control Register         | 0x0000_0000 |
| <b>TIMER0_PWM_CNT</b>         | TMR01_BA+0x5C | R   | Timer0 PWM Counter Register                   | 0x0000_0000 |
| <b>TIMER0_PWM_MSKEN</b>       | TMR01_BA+0x60 | R/W | Timer0 PWM Output Mask Enable Register        | 0x0000_0000 |
| <b>TIMER0_PWM_MSK</b>         | TMR01_BA+0x64 | R/W | Timer0 PWM Output Mask Data Control Register  | 0x0000_0000 |
| <b>TIMER0_PWM_BNF</b>         | TMR01_BA+0x68 | R/W | Timer0 PWM Brake Pin Noise Filter Register    | 0x0000_0000 |
| <b>TIMER0_PWM_FAILBRK</b>     | TMR01_BA+0x6C | R/W | Timer0 PWM System Fail Brake Control Register | 0x0000_0000 |

|                           |                |     |                                                    |             |
|---------------------------|----------------|-----|----------------------------------------------------|-------------|
| <b>TIMER0_PWM_BRKCTL</b>  | TMR01_BA+0x70  | R/W | Timer0 PWM Brake Control Register                  | 0x0000_0000 |
| <b>TIMER0_PWM_POLCTL</b>  | TMR01_BA+0x74  | R/W | Timer0 PWM Pin Output Polar Control Register       | 0x0000_0000 |
| <b>TIMER0_PWM_POEN</b>    | TMR01_BA+0x78  | R/W | Timer0 PWM Pin Output Enable Register              | 0x0000_0000 |
| <b>TIMER0_PWM_SWBRK</b>   | TMR01_BA+0x7C  | W   | Timer0 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| <b>TIMER0_PWM_INTENO</b>  | TMR01_BA+0x80  | R/W | Timer0 PWM Interrupt Enable Register 0             | 0x0000_0000 |
| <b>TIMER0_PWM_INTEN1</b>  | TMR01_BA+0x84  | R/W | Timer0 PWM Interrupt Enable Register 1             | 0x0000_0000 |
| <b>TIMER0_PWM_INTSTS0</b> | TMR01_BA+0x88  | R/W | Timer0 PWM Interrupt Status Register 0             | 0x0000_0000 |
| <b>TIMER0_PWM_INTSTS1</b> | TMR01_BA+0x8C  | R/W | Timer0 PWM Interrupt Status Register 1             | 0x0000_0000 |
| <b>TIMER0_PWM_ADCTS</b>   | TMR01_BA+0x90  | R/W | Timer0 PWM ADC Trigger Source Select Register      | 0x0000_0000 |
| <b>TIMER0_PWM_SCTL</b>    | TMR01_BA+0x94  | R/W | Timer0 PWM Synchronous Control Register            | 0x0000_0000 |
| <b>TIMER0_PWM_STRG</b>    | TMR01_BA+0x98  | W   | Timer0 PWM Synchronous Trigger Register            | 0x0000_0000 |
| <b>TIMER0_PWM_STATUS</b>  | TMR01_BA+0x9C  | R/W | Timer0 PWM Status Register                         | 0x0000_0000 |
| <b>TIMER0_PWM_PBUF</b>    | TMR01_BA+0xA0  | R   | Timer0 PWM Period Buffer Register                  | 0x0000_0000 |
| <b>TIMER0_PWM_CMPBUF</b>  | TMR01_BA+0xA4  | R   | Timer0 PWM Comparator Buffer Register              | 0x0000_0000 |
| <b>TIMER1_CTL</b>         | TMR01_BA+0x100 | R/W | Timer1 Control Register                            | 0x0000_0005 |
| <b>TIMER1_CMP</b>         | TMR01_BA+0x104 | R/W | Timer1 Comparator Register                         | 0x0000_0000 |
| <b>TIMER1_INTS_TS</b>     | TMR01_BA+0x108 | R/W | Timer1 Interrupt Status Register                   | 0x0000_0000 |
| <b>TIMER1_CNT</b>         | TMR01_BA+0x10C | R/W | Timer1 Data Register                               | 0x0000_0000 |
| <b>TIMER1_CAP</b>         | TMR01_BA+0x110 | R   | Timer1 Capture Data Register                       | 0x0000_0000 |
| <b>TIMER1_EXT_CTL</b>     | TMR01_BA+0x114 | R/W | Timer1 External Control Register                   | 0x0000_0000 |
| <b>TIMER1_EINT_STS</b>    | TMR01_BA+0x118 | R/W | Timer1 External Interrupt Status Register          | 0x0000_0000 |
| <b>TIMER1_TRG_CTL</b>     | TMR01_BA+0x11C | R/W | Timer1 Trigger Control Register                    | 0x0000_0000 |
| <b>TIMER1_ALT_CTL</b>     | TMR01_BA+0x120 | R/W | Timer1 Alternative Control Register                | 0x0000_0000 |
| <b>TIMER1_PWM_CTL</b>     | TMR01_BA+0x140 | R/W | Timer1 PWM Control Register                        | 0x0000_0000 |
| <b>TIMER1_PWM</b>         | TMR01_BA+0x144 | R/W | Timer1 PWM Counter Clock Source Register           | 0x0000_0000 |

| CLKSRC             |                |     |                                                    |             |
|--------------------|----------------|-----|----------------------------------------------------|-------------|
| TIMER1_PWM_CLKPSC  | TMR01_BA+0x148 | R/W | Timer1 PWM Counter Clock Pre-scale Register        | 0x0000_0000 |
| TIMER1_PWM_CNTCLR  | TMR01_BA+0x14C | R/W | Timer1 PWM Clear Counter Register                  | 0x0000_0000 |
| TIMER1_PWM_PERIOD  | TMR01_BA+0x150 | R/W | Timer1 PWM Period Register                         | 0x0000_0000 |
| TIMER1_PWM_CMPDAT  | TMR01_BA+0x154 | R/W | Timer1 PWM Comparator Register                     | 0x0000_0000 |
| TIMER1_PWM_DTCTL   | TMR01_BA+0x158 | R/W | Timer1 PWM Dead-Time Control Register              | 0x0000_0000 |
| TIMER1_PWM_CNT     | TMR01_BA+0x15C | R   | Timer1 PWM Counter Register                        | 0x0000_0000 |
| TIMER1_PWM_MSKEN   | TMR01_BA+0x160 | R/W | Timer1 PWM Output Mask Enable Register             | 0x0000_0000 |
| TIMER1_PWM_MSK     | TMR01_BA+0x164 | R/W | Timer1 PWM Output Mask Data Control Register       | 0x0000_0000 |
| TIMER1_PWM_BNF     | TMR01_BA+0x168 | R/W | Timer1 PWM Brake Pin Noise Filter Register         | 0x0000_0000 |
| TIMER1_PWM_FAILBRK | TMR01_BA+0x16C | R/W | Timer1 PWM System Fail Brake Control Register      | 0x0000_0000 |
| TIMER1_PWM_BRKCTL  | TMR01_BA+0x170 | R/W | Timer1 PWM Brake Control Register                  | 0x0000_0000 |
| TIMER1_PWM_POLCTL  | TMR01_BA+0x174 | R/W | Timer1 PWM Pin Output Polar Control Register       | 0x0000_0000 |
| TIMER1_PWM_POEN    | TMR01_BA+0x178 | R/W | Timer1 PWM Pin Output Enable Register              | 0x0000_0000 |
| TIMER1_PWM_SWBRK   | TMR01_BA+0x17C | W   | Timer1 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| TIMER1_PWM_INTENO  | TMR01_BA+0x180 | R/W | Timer1 PWM Interrupt Enable Register 0             | 0x0000_0000 |
| TIMER1_PWM_INTEN1  | TMR01_BA+0x184 | R/W | Timer1 PWM Interrupt Enable Register 1             | 0x0000_0000 |
| TIMER1_PWM_INTSTS0 | TMR01_BA+0x188 | R/W | Timer1 PWM Interrupt Status Register 0             | 0x0000_0000 |
| TIMER1_PWM_INTSTS1 | TMR01_BA+0x18C | R/W | Timer1 PWM Interrupt Status Register 1             | 0x0000_0000 |
| TIMER1_PWM_ADCTS   | TMR01_BA+0x190 | R/W | Timer1 PWM ADC Trigger Source Select Register      | 0x0000_0000 |
| TIMER1_PWM_SCTL    | TMR01_BA+0x194 | R/W | Timer1 PWM Synchronous Control Register            | 0x0000_0000 |
| TIMER1_PWM_STATUS  | TMR01_BA+0x19C | R/W | Timer1 PWM Status Register                         | 0x0000_0000 |
| TIMER1_PWM_PBUF    | TMR01_BA+0x1A0 | R   | Timer1 PWM Period Buffer Register                  | 0x0000_0000 |
| TIMER1_PWM_CMPBUF  | TMR01_BA+0x1A4 | R   | Timer1 PWM Comparator Buffer Register              | 0x0000_0000 |

|                           |               |     |                                                    |             |
|---------------------------|---------------|-----|----------------------------------------------------|-------------|
| <b>TIMER2_CTL</b>         | TMR23_BA+0x00 | R/W | Timer2 Control Register                            | 0x0000_0005 |
| <b>TIMER2_CMP</b>         | TMR23_BA+0x04 | R/W | Timer2 Comparator Register                         | 0x0000_0000 |
| <b>TIMER2_INTS_TS</b>     | TMR23_BA+0x08 | R/W | Timer2 Interrupt Status Register                   | 0x0000_0000 |
| <b>TIMER2_CNT</b>         | TMR23_BA+0x0C | R/W | Timer2 Data Register                               | 0x0000_0000 |
| <b>TIMER2_CAP</b>         | TMR23_BA+0x10 | R   | Timer2 Capture Data Register                       | 0x0000_0000 |
| <b>TIMER2_EXT_CTL</b>     | TMR23_BA+0x14 | R/W | Timer2 External Control Register                   | 0x0000_0000 |
| <b>TIMER2_EINT_STS</b>    | TMR23_BA+0x18 | R/W | Timer2 External Interrupt Status Register          | 0x0000_0000 |
| <b>TIMER2_TRG_CTL</b>     | TMR23_BA+0x1C | R/W | Timer2 Trigger Control Register                    | 0x0000_0000 |
| <b>TIMER2_ALT_CTL</b>     | TMR23_BA+0x20 | R/W | Timer2 Alternative Control Register                | 0x0000_0000 |
| <b>TIMER2_PWM_CTL</b>     | TMR23_BA+0x40 | R/W | Timer2 PWM Control Register                        | 0x0000_0000 |
| <b>TIMER2_PWM_CLKSRC</b>  | TMR23_BA+0x44 | R/W | Timer2 PWM Counter Clock Source Register           | 0x0000_0000 |
| <b>TIMER2_PWM_CLKPSC</b>  | TMR23_BA+0x48 | R/W | Timer2 PWM Counter Clock Pre-scale Register        | 0x0000_0000 |
| <b>TIMER2_PWM_CNTCLR</b>  | TMR23_BA+0x4C | R/W | Timer2 PWM Clear Counter Register                  | 0x0000_0000 |
| <b>TIMER2_PWM_PERIOD</b>  | TMR23_BA+0x50 | R/W | Timer2 PWM Period Register                         | 0x0000_0000 |
| <b>TIMER2_PWM_CMPDAT</b>  | TMR23_BA+0x54 | R/W | Timer2 PWM Comparator Register                     | 0x0000_0000 |
| <b>TIMER2_PWM_DTCTL</b>   | TMR23_BA+0x58 | R/W | Timer2 PWM Dead-Time Control Register              | 0x0000_0000 |
| <b>TIMER2_PWM_CNT</b>     | TMR23_BA+0x5C | R   | Timer2 PWM Counter Register                        | 0x0000_0000 |
| <b>TIMER2_PWM_MSKEN</b>   | TMR23_BA+0x60 | R/W | Timer2 PWM Output Mask Enable Register             | 0x0000_0000 |
| <b>TIMER2_PWM_MSK</b>     | TMR23_BA+0x64 | R/W | Timer2 PWM Output Mask Data Control Register       | 0x0000_0000 |
| <b>TIMER2_PWM_BNF</b>     | TMR23_BA+0x68 | R/W | Timer2 PWM Brake Pin Noise Filter Register         | 0x0000_0000 |
| <b>TIMER2_PWM_FAILBRK</b> | TMR23_BA+0x6C | R/W | Timer2 PWM System Fail Brake Control Register      | 0x0000_0000 |
| <b>TIMER2_PWM_BRKCTL</b>  | TMR23_BA+0x70 | R/W | Timer2 PWM Brake Control Register                  | 0x0000_0000 |
| <b>TIMER2_PWM_POLCTL</b>  | TMR23_BA+0x74 | R/W | Timer2 PWM Pin Output Polar Control Register       | 0x0000_0000 |
| <b>TIMER2_PWM_POEN</b>    | TMR23_BA+0x78 | R/W | Timer2 PWM Pin Output Enable Register              | 0x0000_0000 |
| <b>TIMER2_PWM</b>         | TMR23_BA+0x7C | W   | Timer2 PWM Software Trigger Brake Control Register | 0x0000_0000 |

|                           |                |     |                                               |             |
|---------------------------|----------------|-----|-----------------------------------------------|-------------|
| <b>SWBRK</b>              |                |     |                                               |             |
| <b>TIMER2_PWM_INTENO</b>  | TMR23_BA+0x80  | R/W | Timer2 PWM Interrupt Enable Register 0        | 0x0000_0000 |
| <b>TIMER2_PWM_INTEN1</b>  | TMR23_BA+0x84  | R/W | Timer2 PWM Interrupt Enable Register 1        | 0x0000_0000 |
| <b>TIMER2_PWM_INTSTS0</b> | TMR23_BA+0x88  | R/W | Timer2 PWM Interrupt Status Register 0        | 0x0000_0000 |
| <b>TIMER2_PWM_INTSTS1</b> | TMR23_BA+0x8C  | R/W | Timer2 PWM Interrupt Status Register 1        | 0x0000_0000 |
| <b>TIMER2_PWM_ADCTS</b>   | TMR23_BA+0x90  | R/W | Timer2 PWM ADC Trigger Source Select Register | 0x0000_0000 |
| <b>TIMER2_PWM_SCTL</b>    | TMR23_BA+0x94  | R/W | Timer2 PWM Synchronous Control Register       | 0x0000_0000 |
| <b>TIMER2_PWM_STRG</b>    | TMR23_BA+0x98  | W   | Timer2 PWM Synchronous Trigger Register       | 0x0000_0000 |
| <b>TIMER2_PWM_STATUS</b>  | TMR23_BA+0x9C  | R/W | Timer2 PWM Status Register                    | 0x0000_0000 |
| <b>TIMER2_PWM_PBUF</b>    | TMR23_BA+0xA0  | R   | Timer2 PWM Period Buffer Register             | 0x0000_0000 |
| <b>TIMER2_PWM_CMPBUF</b>  | TMR23_BA+0xA4  | R   | Timer2 PWM Comparator Buffer Register         | 0x0000_0000 |
| <b>TIMER3_CTL</b>         | TMR23_BA+0x100 | R/W | Timer3 Control Register                       | 0x0000_0005 |
| <b>TIMER3_CMP</b>         | TMR23_BA+0x104 | R/W | Timer3 Comparator Register                    | 0x0000_0000 |
| <b>TIMER3_INTS_TS</b>     | TMR23_BA+0x108 | R/W | Timer3 Interrupt Status Register              | 0x0000_0000 |
| <b>TIMER3_CNT</b>         | TMR23_BA+0x10C | R/W | Timer3 Data Register                          | 0x0000_0000 |
| <b>TIMER3_CAP</b>         | TMR23_BA+0x110 | R   | Timer3 Capture Data Register                  | 0x0000_0000 |
| <b>TIMER3_EXT_CTL</b>     | TMR23_BA+0x114 | R/W | Timer3 External Control Register              | 0x0000_0000 |
| <b>TIMER3_EINT_STS</b>    | TMR23_BA+0x118 | R/W | Timer3 External Interrupt Status Register     | 0x0000_0000 |
| <b>TIMER3_TRG_CTL</b>     | TMR23_BA+0x11C | R/W | Timer3 Trigger Control Register               | 0x0000_0000 |
| <b>TIMER3_ALT_CTL</b>     | TMR23_BA+0x120 | R/W | Timer3 Alternative Control Register           | 0x0000_0000 |
| <b>TIMER3_PWM_CTL</b>     | TMR23_BA+0x140 | R/W | Timer3 PWM Control Register                   | 0x0000_0000 |
| <b>TIMER3_PWM_CLKSRC</b>  | TMR23_BA+0x144 | R/W | Timer3 PWM Counter Clock Source Register      | 0x0000_0000 |
| <b>TIMER3_PWM_CLKPSC</b>  | TMR23_BA+0x148 | R/W | Timer3 PWM Counter Clock Pre-scale Register   | 0x0000_0000 |
| <b>TIMER3_PWM_CNTCLR</b>  | TMR23_BA+0x14C | R/W | Timer3 PWM Clear Counter Register             | 0x0000_0000 |
| <b>TIMER3_PWM_PERIOD</b>  | TMR23_BA+0x150 | R/W | Timer3 PWM Period Register                    | 0x0000_0000 |

|                           |                |     |                                                    |             |
|---------------------------|----------------|-----|----------------------------------------------------|-------------|
| <b>TIMER3_PWM_CMPDAT</b>  | TMR23_BA+0x154 | R/W | Timer3 PWM Comparator Register                     | 0x0000_0000 |
| <b>TIMER3_PWM_DTCCTL</b>  | TMR23_BA+0x158 | R/W | Timer3 PWM Dead-Time Control Register              | 0x0000_0000 |
| <b>TIMER3_PWM_CNT</b>     | TMR23_BA+0x15C | R   | Timer3 PWM Counter Register                        | 0x0000_0000 |
| <b>TIMER3_PWM_MSKEN</b>   | TMR23_BA+0x160 | R/W | Timer3 PWM Output Mask Enable Register             | 0x0000_0000 |
| <b>TIMER3_PWM_MSK</b>     | TMR23_BA+0x164 | R/W | Timer3 PWM Output Mask Data Control Register       | 0x0000_0000 |
| <b>TIMER3_PWM_BNF</b>     | TMR23_BA+0x168 | R/W | Timer3 PWM Brake Pin Noise Filter Register         | 0x0000_0000 |
| <b>TIMER3_PWM_FAILBRK</b> | TMR23_BA+0x16C | R/W | Timer3 PWM System Fail Brake Control Register      | 0x0000_0000 |
| <b>TIMER3_PWM_BRKCTL</b>  | TMR23_BA+0x170 | R/W | Timer3 PWM Brake Control Register                  | 0x0000_0000 |
| <b>TIMER3_PWM_POLCTL</b>  | TMR23_BA+0x174 | R/W | Timer3 PWM Pin Output Polar Control Register       | 0x0000_0000 |
| <b>TIMER3_PWM_POEN</b>    | TMR23_BA+0x178 | R/W | Timer3 PWM Pin Output Enable Register              | 0x0000_0000 |
| <b>TIMER3_PWM_SWBRK</b>   | TMR23_BA+0x17C | W   | Timer3 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| <b>TIMER3_PWM_INTENO</b>  | TMR23_BA+0x180 | R/W | Timer3 PWM Interrupt Enable Register 0             | 0x0000_0000 |
| <b>TIMER3_PWM_INTEN1</b>  | TMR23_BA+0x184 | R/W | Timer3 PWM Interrupt Enable Register 1             | 0x0000_0000 |
| <b>TIMER3_PWM_INTSTS0</b> | TMR23_BA+0x188 | R/W | Timer3 PWM Interrupt Status Register 0             | 0x0000_0000 |
| <b>TIMER3_PWM_INTSTS1</b> | TMR23_BA+0x18C | R/W | Timer3 PWM Interrupt Status Register 1             | 0x0000_0000 |
| <b>TIMER3_PWM_ADCTS</b>   | TMR23_BA+0x190 | R/W | Timer3 PWM ADC Trigger Source Select Register      | 0x0000_0000 |
| <b>TIMER3_PWM_SCTL</b>    | TMR23_BA+0x194 | R/W | Timer3 PWM Synchronous Control Register            | 0x0000_0000 |
| <b>TIMER3_PWM_STATUS</b>  | TMR23_BA+0x19C | R/W | Timer3 PWM Status Register                         | 0x0000_0000 |
| <b>TIMER3_PWM_PBUF</b>    | TMR23_BA+0x1A0 | R   | Timer3 PWM Period Buffer Register                  | 0x0000_0000 |
| <b>TIMER3_PWM_CMPBUF</b>  | TMR23_BA+0x1A4 | 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 |  |  |  | 0x0000_0005 |
| TIMER1_CTL | TMR01_BA+0x100 | R/W | Timer1 Control Register |  |  |  | 0x0000_0005 |
| TIMER2_CTL | TMR23_BA+0x00  | R/W | Timer2 Control Register |  |  |  | 0x0000_0005 |
| TIMER3_CTL | TMR23_BA+0x100 | R/W | Timer3 Control Register |  |  |  | 0x0000_0005 |

|          |        |           |          |         |          |        |          |
|----------|--------|-----------|----------|---------|----------|--------|----------|
| 31       | 30     | 29        | 28       | 27      | 26       | 25     | 24       |
| ICEDEBUG | CNTEN  | INTEN     | 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        |
| Reserved |        |           |          |         |          |        |          |
| 7        | 6      | 5         | 4        | 3       | 2        | 1      | 0        |
| PSC      |        |           |          |         |          |        |          |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>ICEDEBUG</b><br><br>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><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                          |
| [30]    | <b>CNTEN</b><br><br>Timer Counting Enable Bit<br>0 = Stops/Suspends counting.<br>1 = Starts counting.<br><b>Note1:</b> In stop status, and then set CNTEN to 1 will enable the 24-bit up counter to keep counting from the last stop counting value.<br><b>Note2:</b> This bit is auto-cleared by hardware in one-shot mode (TIMER_CTL[28:27] = 00) when the timer time-out interrupt flag TIF (TIMERx_INTSTS[0]) is generated.<br><b>Note3:</b> Set enable/disable this bit needs 2 * TMR_CLK period to become active, user can read ACTSTS (TIMERx_CTL[25]) to check enable/disable command is completed or not. |
| [29]    | <b>INTEN</b><br><br>Timer Interrupt Enable Bit<br>0 = Timer time-out interrupt Disabled.<br>1 = Timer time-out interrupt Enabled.<br><b>Note:</b> If this bit is enabled, when the timer time-out interrupt flag TIF is set to 1, the timer interrupt signal is generated and inform to CPU.                                                                                                                                                                                                                                                                                                                       |
| [28:27] | <b>OPMODE</b><br><br>Timer Counting Mode Select<br>00 = The timer controller is operated in One-shot mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|      |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  | 01 = The timer controller is operated in Periodic mode.<br>10 = The timer controller is operated in Toggle-output mode.<br>11 = The timer controller is operated in Continuous Counting mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [26] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [25] | <b>ACTSTS</b>    | <p><b>Timer Active Status Bit (Read Only)</b><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.</p> <p><b>Note:</b> This bit may active when CNT 0 transition to CNT 1.</p>                                                                                                                                                                                                                                                                                                                                                                                                              |
| [24] | <b>EXTCNTEN</b>  | <p><b>Event Counter Mode Enable Bit</b><br/> This bit is for external counting pin function enabled.<br/> 0 = Event counter mode Disabled.<br/> 1 = Event counter mode Enabled.</p> <p><b>Note:</b> When timer is used as an event counter, this bit should be set to 1 and select PCLK as timer clock source.</p>                                                                                                                                                                                                                                                                                                                                                           |
| [23] | <b>WKEN</b>      | <p><b>Wake-up Function Enable Bit</b><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.</p>                                                                                                                                                                                                                                                                                |
| [22] | <b>CAPSRC</b>    | <p><b>Capture Pin Source Selection</b><br/> 0 = Capture Function source is from TMx_EXT (x= 0~3) pin.<br/> 1 = Capture Function source is from internal ACMP output signal. User can set ACMPSEL (TIMERx_EXTCTL[8]) to decide which internal ACMP output signal as timer capture source.</p>                                                                                                                                                                                                                                                                                                                                                                                 |
| [21] | <b>TGLPINSEL</b> | <p><b>Toggle-output Pin Select</b><br/> 0 = Toggle mode output to TMx (Timer Event Counter Pin).<br/> 1 = Toggle mode output to TMx_EXT (Timer External Capture Pin).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [20] | <b>PERIOSEL</b>  | <p><b>Periodic Mode Behavior Selection Enable Bit</b><br/> 0 = The behavior selection in periodic mode is Disabled.<br/> When user updates CMPDAT while timer is running in periodic mode, CNT will be reset to default value.<br/> 1 = The behavior selection in periodic mode is Enabled.<br/> When user update CMPDAT while timer is running in periodic mode, the limitations as bellows list,<br/> If updated CMPDAT value &gt; 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 &lt; CNT, CNT will be reset to default value.</p> |
| [19] | <b>INTRGEN</b>   | <p><b>Inter-timer Trigger Mode Enable Bit</b><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.<br/> Also, Timer1/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.</p> <p><b>Note:</b> For Timer1/3, this bit is ignored and the read back value is always 0</p>                                                                                                                                                                   |

|        |          |                                                                                                                                                                                                                                                                                                            |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [18:8] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                  |
| [7:0]  | PSC      | <b>Prescale Counter</b><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 (PSC = 0), then there is no scaling.<br><b>Note:</b> 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 | 0x0000_0000 |
| TIMER1_CMP | TMR01_BA+0x104 | R/W | Timer1 Comparator Register | 0x0000_0000 |
| TIMER2_CMP | TMR23_BA+0x04  | R/W | Timer2 Comparator Register | 0x0000_0000 |
| TIMER3_CMP | TMR23_BA+0x104 | R/W | Timer3 Comparator Register | 0x0000_0000 |



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

**Timer Interrupt Status Register (TIMERx\_INTSTS)**

| Register             | Offset         | R/W | Description                      | Reset Value |
|----------------------|----------------|-----|----------------------------------|-------------|
| <b>TIMER0_INTSTS</b> | TMR01_BA+0x08  | R/W | Timer0 Interrupt Status Register | 0x0000_0000 |
| <b>TIMER1_INTSTS</b> | TMR01_BA+0x108 | R/W | Timer1 Interrupt Status Register | 0x0000_0000 |
| <b>TIMER2_INTSTS</b> | TMR23_BA+0x08  | R/W | Timer2 Interrupt Status Register | 0x0000_0000 |
| <b>TIMER3_INTSTS</b> | 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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                         |
| [1]    | <b>TWKF</b>     | <p><b>Timer Wake-up Flag</b></p> <p>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.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p>                       |
| [0]    | <b>TIF</b>      | <p><b>Timer Interrupt Flag</b></p> <p>This bit indicates the interrupt flag status of Timer while 24-bit timer up counter CNT (TIMERx_CNT[23:0]) value reaches to CMPDAT (TIMERx_CMP[23:0]) value.<br/>0 = No effect.<br/>1 = CNT value matches the CMPDAT value.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p> |

**Timer Data Register (TIMERx\_CNT)**

| Register   | Offset         | R/W | Description          | Reset Value |
|------------|----------------|-----|----------------------|-------------|
| TIMER0_CNT | TMR01_BA+0x0C  | R/W | Timer0 Data Register | 0x0000_0000 |
| TIMER1_CNT | TMR01_BA+0x10C | R/W | Timer1 Data Register | 0x0000_0000 |
| TIMER2_CNT | TMR23_BA+0x0C  | R/W | Timer2 Data Register | 0x0000_0000 |
| TIMER3_CNT | TMR23_BA+0x10C | R/W | Timer3 Data Register | 0x0000_0000 |



| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>RSTACT</b>   | <b>Timer Data Register Reset Active (Read Only)</b><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-bit pre-scale counter. At the same time, timer set this flag to 1 to indicate the counter reset operation is in 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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [23:0]  | <b>CNT</b>      | <b>Timer Data Register</b><br>Read operation.<br>Read this register to get CNT value. For example:<br>If 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 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+0x10  | R   | Timer0 Capture Data Register | 0x0000_0000 |
| TIMER1_CAP | TMR01_BA+0x110 | R   | Timer1 Capture Data Register | 0x0000_0000 |
| TIMER2_CAP | TMR23_BA+0x10  | R   | Timer2 Capture Data Register | 0x0000_0000 |
| TIMER3_CAP | TMR23_BA+0x110 | R   | Timer3 Capture Data Register | 0x0000_0000 |



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

**Timer External Control Register (TIMERx\_EXTCTL)**

| Register      | Offset         | R/W | Description                      | Reset Value |
|---------------|----------------|-----|----------------------------------|-------------|
| TIMER0_EXTCTL | TMR01_BA+0x14  | R/W | Timer0 External Control Register | 0x0000_0000 |
| TIMER1_EXTCTL | TMR01_BA+0x114 | R/W | Timer1 External Control Register | 0x0000_0000 |
| TIMER2_EXTCTL | TMR23_BA+0x14  | R/W | Timer2 External Control Register | 0x0000_0000 |
| TIMER3_EXTCTL | TMR23_BA+0x114 | R/W | Timer3 External Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [16]    | ECNTSSEL    | <b>Event Counter Source Selection to Trigger Event Counter Function</b><br>0 = Event Counter input source is from TMx (x= 0~3) pin.<br>1 = Event Counter input source is from USB internal SOF output signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [14:12] | CAPEDGE     | <b>Timer External Capture Pin Edge Detect</b><br>When first capture event is generated, the CNT (TIMERx_CNT[23:0]) will be reset to 0 and first CAPDAT (TIMERx_CAP[23:0]) should be to 0.<br>000 = Capture event occurred when detect falling edge transfer on TMx_EXT (x= 0~3) pin.<br>001 = Capture event occurred when detect rising edge transfer on TMx_EXT (x= 0~3) pin.<br>010 = Capture event occurred when detect both falling and rising edge transfer on TMx_EXT (x= 0~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~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~3) pin.<br>100, 101 = Reserved. |
| [11:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [8]     | ACMPSSEL    | <b>ACMP Source Selection to Trigger Capture Function</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|       |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 0 = Capture Function source is from internal ACMP0 output signal.<br>1 = Capture Function source is from internal ACMP1 output signal.<br><b>Note:</b> these bits only available when CAPSRC (TIMERx_CTL[22]) is 1.                                                                                                                                                                                                                                                                                                                       |
| [7]   | CNTDBEN  | <b>Timer Counter Pin De-bounce Enable Bit</b><br>0 = TMx (x= 0~3) pin de-bounce Disabled.<br>1 = TMx (x= 0~3) pin de-bounce Enabled.<br><b>Note:</b> If this bit is enabled, the edge detection of TMx pin is detected with de-bounce circuit.                                                                                                                                                                                                                                                                                            |
| [6]   | CAPDBEN  | <b>Timer External Capture Pin De-bounce Enable Bit</b><br>0 = TMx_EXT (x= 0~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><b>Note:</b> If this bit is enabled, the edge detection of TMx_EXT pin or ACMP output is detected with de-bounce circuit.                                                                                                                                                                                                      |
| [5]   | CAPIEN   | <b>Timer External Capture Interrupt Enable Bit</b><br>0 = TMx_EXT (x= 0~3) pin detection Interrupt Disabled.<br>1 = TMx_EXT (x= 0~3) pin detection Interrupt Enabled.<br><b>Note:</b> CAPIEN is used to enable timer external interrupt. If CAPIEN enabled, timer will rise an interrupt when CAPIF (TIMERx_EINTSTS[0]) is 1.<br>For example, while CAPIEN = 1, CAPEN = 1, and CAPEDGE = 00, a 1 to 0 transition on the TMx_EXT pin will cause the CAPIF to be set then the interrupt signal is generated and sent to NVIC to inform CPU. |
| [4]   | CAPFUNCS | <b>Capture Function Selection</b><br>0 = External Capture Mode Enabled.<br>1 = External Reset Mode Enabled.<br><b>Note1:</b> When CAPFUNCS is 0, transition on TMx_EXT (x= 0~3) pin is using to save current 24-bit timer counter value (CNT value) to CAPDAT field.<br><b>Note2:</b> When CAPFUNCS is 1, transition on TMx_EXT (x= 0~3) pin is using to save current 24-bit timer counter value (CNT value) to CAPDAT field then CNT value will be reset immediately.                                                                    |
| [3]   | CAPEN    | <b>Timer External Capture Pin Enable Bit</b><br>This bit enables the TMx_EXT capture pin input function.<br>0 =TMx_EXT (x= 0~3) pin Disabled.<br>1 =TMx_EXT (x= 0~3) pin Enabled.                                                                                                                                                                                                                                                                                                                                                         |
| [2:1] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [0]   | CNTPHASE | <b>Timer External Count Phase</b><br>This bit indicates the detection phase of external counting pin TMx (x= 0~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 | 0x0000_0000 |
| TIMER1_EINTSTS | TMR01_BA+0x118 | R/W | Timer1 External Interrupt Status Register | 0x0000_0000 |
| TIMER2_EINTSTS | TMR23_BA+0x18  | R/W | Timer2 External Interrupt Status Register | 0x0000_0000 |
| TIMER3_EINTSTS | TMR23_BA+0x118 | R/W | Timer3 External Interrupt Status Register | 0x0000_0000 |

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

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

**Timer Trigger Control Register (TIMERx\_TRGCTL)**

| Register      | Offset         | R/W | Description                     | Reset Value |
|---------------|----------------|-----|---------------------------------|-------------|
| TIMER0_TRGCTL | TMR01_BA+0x1C  | R/W | Timer0 Trigger Control Register | 0x0000_0000 |
| TIMER1_TRGCTL | TMR01_BA+0x11C | R/W | Timer1 Trigger Control Register | 0x0000_0000 |
| TIMER2_TRGCTL | TMR23_BA+0x1C  | R/W | Timer2 Trigger Control Register | 0x0000_0000 |
| TIMER3_TRGCTL | TMR23_BA+0x11C | R/W | Timer3 Trigger Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [4]    | TRGPDMA     | <p><b>Trigger PDMA Enable Bit</b><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.</p> <p><b>Note:</b> 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.</p> |
| [3]    | TRGDAC      | <p><b>Trigger DAC Enable Bit</b><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.</p> <p><b>Note:</b> 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.</p>                               |
| [2]    | TRGEADC     | <p><b>Trigger EADC Enable Bit</b><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.<br/> 1 = Timer interrupt trigger EADC Enabled.</p> <p><b>Note:</b> If TRGSSEL (TIMERx_TRGCTL[0]) = 0, time-out interrupt signal will trigger EADC</p>                                                                                                      |

|     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         | conversion.<br>If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal will trigger ADC conversion.                                                                                                                                                                                                                                                                                                                                       |
| [1] | TRGPWM  | <b>Trigger EPWM Enable Bit</b><br>If this bit is set to 1, each timer time-out event or capture event can be as EPWM counter clock source.<br>0 = Timer interrupt trigger EPWM Disabled.<br>1 = Timer interrupt trigger EPWM Enabled.<br><b>Note:</b> If TRGSSEL (TIMERx_TRGCTL[0]) = 0, time-out interrupt signal as EPWM counter clock source.<br>If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal as EPWM counter clock source. |
| [0] | TRGSSEL | <b>Trigger Source Select Bit</b><br>This bit is used to select internal trigger source is form timer time-out interrupt signal or capture interrupt signal.<br>0 = Time-out interrupt signal is used to internal trigger EPWM, PDMA, DAC, and ADC.<br>1 = Capture interrupt signal is used to internal trigger EPWM, PDMA, DAC, and ADC.                                                                                                      |

**Timer Alternative Control Register (TIMERx\_ALTCTL)**

| Register       | Offset         | R/W | Description                         | Reset Value |
|----------------|----------------|-----|-------------------------------------|-------------|
| TIMER0_ALT_CTL | TMR01_BA+0x20  | R/W | Timer0 Alternative Control Register | 0x0000_0000 |
| TIMER1_ALT_CTL | TMR01_BA+0x120 | R/W | Timer1 Alternative Control Register | 0x0000_0000 |
| TIMER2_ALT_CTL | TMR23_BA+0x20  | R/W | Timer2 Alternative Control Register | 0x0000_0000 |
| TIMER3_ALT_CTL | TMR23_BA+0x120 | R/W | Timer3 Alternative Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                     |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                           |
| [0]    | FUNCSEL     | <p><b>Function Selection</b></p> <p>0 = timer controller is used as timer function.<br/>1 = timer controller is used as PWM function.</p> <p><b>Note:</b> When timer is used as PWM, the clock source of time controller will be forced to PCLKx automatically.</p> |

**Timer PWM Control Register (TIMERx\_PWMCTL)**

| Register       | Offset         | R/W | Description                 |  |  |  | Reset Value |
|----------------|----------------|-----|-----------------------------|--|--|--|-------------|
| TIMER0_PWM_CTL | TMR01_BA+0x40  | R/W | Timer0 PWM Control Register |  |  |  | 0x0000_0000 |
| TIMER1_PWM_CTL | TMR01_BA+0x140 | R/W | Timer1 PWM Control Register |  |  |  | 0x0000_0000 |
| TIMER2_PWM_CTL | TMR23_BA+0x40  | R/W | Timer2 PWM Control Register |  |  |  | 0x0000_0000 |
| TIMER3_PWM_CTL | TMR23_BA+0x140 | R/W | Timer3 PWM Control Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>DBGTRIOFF</b><br><b>ICE Debug Mode Acknowledge Disable Bit (Write Protect)</b><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><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [30]    | <b>DBGHALT</b><br><b>ICE Debug Mode Counter Halt (Write Protect)</b><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 disable.<br>1 = ICE debug mode counter halt enable.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                          |
| [29:17] | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [16]    | <b>OUTMODE</b><br><b>PWM Output Mode</b><br>This bit controls the output mode of corresponding PWM channel.<br>0 = PWM independent mode.<br>1 = PWM complementary mode.                                                                                                                                                                                                                                                                   |
| [15:10] | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [9]     | <b>IMMLDEN</b><br><b>Immediately Load Enable Bit</b><br>0 = PERIOD will load to PBUF when current PWM period is completed no matter CTRLD is enabled/disabled. If CTRLD is disabled, CMP will load to CMPBUF when current PWM                                                                                                                                                                                                             |

|       |                 |                                                                                                                                                                                                                                                                                  |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | period is completed; if CTRLD is enabled in up-down count type, CMP will load to CMPBUF at the center point of current period.<br>1 = PERIOD/CMP will load to PBUF/CMPBUF immediately when user update PERIOD/CMP.<br><b>Note:</b> If IMMLDEN is enabled, CTRLD will be invalid. |
| [8]   | <b>CTRLD</b>    | <b>Center Re-load</b><br>In up-down count type, PERIOD will load to PBUF when current PWM period is completed always and CMP will load to CMPBUF at the center point of current period.                                                                                          |
| [7:4] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                        |
| [3]   | <b>CNTMODE</b>  | <b>PWM Counter Mode</b><br>0 = Auto-reload mode.<br>1 = One-shot mode.                                                                                                                                                                                                           |
| [2:1] | <b>CNTTYPE</b>  | <b>PWM Counter Behavior Type</b><br>00 = Up count type.<br>01 = Down count type.<br>10 = Up-down count type.<br>11 = Reserved.                                                                                                                                                   |
| [0]   | <b>CNTEN</b>    | <b>PWM Counter Enable Bit</b><br>0 = PWM counter and clock prescale Stop Running.<br>1 = PWM counter and clock prescale Start Running.                                                                                                                                           |

**Timer PWM Counter Clock Source Register (TIMERx\_PWMCLKSRC)**

| Register         | Offset         | R/W | Description                              | Reset Value |
|------------------|----------------|-----|------------------------------------------|-------------|
| TIMER0_PWMCLKSRC | TMR01_BA+0x44  | R/W | Timer0 PWM Counter Clock Source Register | 0x0000_0000 |
| TIMER1_PWMCLKSRC | TMR01_BA+0x144 | R/W | Timer1 PWM Counter Clock Source Register | 0x0000_0000 |
| TIMER2_PWMCLKSRC | TMR23_BA+0x44  | R/W | Timer2 PWM Counter Clock Source Register | 0x0000_0000 |
| TIMER3_PWMCLKSRC | TMR23_BA+0x144 | R/W | Timer3 PWM Counter Clock Source Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [2:0]  | CLKSRC      | <p><b>PWM Counter Clock Source Select</b></p> <p>The PWM counter clock source can be selected from TMRx_CLK or internal timer time-out or capture event.</p> <p>000 = TMRx_CLK.<br/>001 = Internal TIMER0 time-out or capture event.<br/>010 = Internal TIMER1 time-out or capture event.<br/>011 = Internal TIMER2 time-out or capture event.<br/>100 = Internal TIMER3 time-out or capture event.<br/>Others = Reserved.</p> <p><b>Note:</b> If TIMER0 PWM function is enabled, the PWM counter clock source can be selected from TMR0_CLK, TIMER1 interrupt events, TIMER2 interrupt events, or TIMER3 interrupt events.</p> |

**Timer PWM Counter Clock Pre-scale Register (TIMERx PWMCLKPSC)**

| Register         | Offset         | R/W | Description                                 | Reset Value |
|------------------|----------------|-----|---------------------------------------------|-------------|
| TIMER0_PWMCLKPSC | TMR01_BA+0x48  | R/W | Timer0 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER1_PWMCLKPSC | TMR01_BA+0x148 | R/W | Timer1 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER2_PWMCLKPSC | TMR23_BA+0x48  | R/W | Timer2 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER3_PWMCLKPSC | TMR23_BA+0x148 | R/W | Timer3 PWM Counter Clock Pre-scale Register | 0x0000_0000 |

|          |    |    |    |        |    |    |    |
|----------|----|----|----|--------|----|----|----|
| 31       | 30 | 29 | 28 | 27     | 26 | 25 | 24 |
| Reserved |    |    |    |        |    |    |    |
| 23       | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
| 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      | <b>PWM Counter Clock Pre-scale</b><br>The active clock of PWM counter is decided by counter clock prescale and divided by (CLKPSC + 1). If CLKPSC is 0, then there is no scaling in PWM counter clock source. |

**Timer PWM Clear Counter Register (TIMERx PWMCNTCLR)**

| Register          | Offset         | R/W | Description                       | Reset Value |
|-------------------|----------------|-----|-----------------------------------|-------------|
| TIMER0_PWM_CNTCLR | TMR01_BA+0x4C  | R/W | Timer0 PWM Clear Counter Register | 0x0000_0000 |
| TIMER1_PWM_CNTCLR | TMR01_BA+0x14C | R/W | Timer1 PWM Clear Counter Register | 0x0000_0000 |
| TIMER2_PWM_CNTCLR | TMR23_BA+0x4C  | R/W | Timer2 PWM Clear Counter Register | 0x0000_0000 |
| TIMER3_PWM_CNTCLR | TMR23_BA+0x14C | R/W | Timer3 PWM Clear Counter Register | 0x0000_0000 |

|          |    |    |    |    |    |    |        |
|----------|----|----|----|----|----|----|--------|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24     |
| Reserved |    |    |    |    |    |    |        |
| 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16     |
| 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      | <p><b>Clear PWM Counter Control Bit</b></p> <p>It is automatically cleared by hardware.</p> <p>0 = No effect.</p> <p>1 = Clear 16-bit PWM counter to 0x10000 in up and up-down count type and reset counter value to PERIOD in down count type.</p> |

**Timer PWM Period Register (TIMERx\_PWMPERIOD)**

| Register          | Offset         | R/W | Description                | Reset Value |
|-------------------|----------------|-----|----------------------------|-------------|
| TIMER0_PWM_PERIOD | TMR01_BA+0x50  | R/W | Timer0 PWM Period Register | 0x0000_0000 |
| TIMER1_PWM_PERIOD | TMR01_BA+0x150 | R/W | Timer1 PWM Period Register | 0x0000_0000 |
| TIMER2_PWM_PERIOD | TMR23_BA+0x50  | R/W | Timer2 PWM Period Register | 0x0000_0000 |
| TIMER3_PWM_PERIOD | TMR23_BA+0x150 | R/W | Timer3 PWM Period Register | 0x0000_0000 |

|          |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| Reserved |    |    |    |    |    |    |    |
| 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| 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      | <p><b>PWM Period Register</b></p> <p>In up count type: PWM counter counts from 0 to PERIOD, and restarts from 0.</p> <p>In down count type: PWM counter counts from PERIOD to 0, and restarts from PERIOD.</p> <p>In up-down count type: PWM counter counts from 0 to PERIOD, then decrements to 0 and repeats again.</p> <p>In up and down count type:</p> <p>PWM period time = (PERIOD + 1) * (CLKPSC + 1) * TMRx_PWMCLK.</p> <p>In up-down count type:</p> <p>PWM period time = 2 * PERIOD * (CLKPSC+ 1) * TMRx_PWMCLK.</p> <p><b>Note:</b> User should take care DIRF (TIMERx_PWMCNT[16]) bit in up/down/up-down count type to monitor current counter direction in each count type.</p> |

**Timer PWM Comparator Register (TIMERx\_PWMCMPPDAT)**

| Register                     | Offset         | R/W | Description                    | Reset Value |
|------------------------------|----------------|-----|--------------------------------|-------------|
| <b>TIMER0_PWM<br/>CMPDAT</b> | TMR01_BA+0x54  | R/W | Timer0 PWM Comparator Register | 0x0000_0000 |
| <b>TIMER1_PWM<br/>CMPDAT</b> | TMR01_BA+0x154 | R/W | Timer1 PWM Comparator Register | 0x0000_0000 |
| <b>TIMER2_PWM<br/>CMPDAT</b> | TMR23_BA+0x54  | R/W | Timer2 PWM Comparator Register | 0x0000_0000 |
| <b>TIMER3_PWM<br/>CMPDAT</b> | TMR23_BA+0x154 | R/W | Timer3 PWM Comparator Register | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                               |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>Reserved</b> | Reserved.                                                                                                                                                     |
| [15:0]  | <b>CMP</b>      | <b>PWM Comparator Register</b><br>PWM CMP is used to compare with PWM CNT to generate PWM output waveform, interrupt events and trigger ADC to start convert. |

**Timer PWM Dead-time Control Register (TIMERx\_PWMDTCTL)**

| Register          | Offset         | R/W | Description                           |  |  |  | Reset Value |
|-------------------|----------------|-----|---------------------------------------|--|--|--|-------------|
| TIMER0_PWM_DTCCTL | TMR01_BA+0x58  | R/W | Timer0 PWM Dead-Time Control Register |  |  |  | 0x0000_0000 |
| TIMER1_PWM_DTCCTL | TMR01_BA+0x158 | R/W | Timer1 PWM Dead-Time Control Register |  |  |  | 0x0000_0000 |
| TIMER2_PWM_DTCCTL | TMR23_BA+0x58  | R/W | Timer2 PWM Dead-Time Control Register |  |  |  | 0x0000_0000 |
| TIMER3_PWM_DTCCTL | TMR23_BA+0x158 | R/W | Timer3 PWM Dead-Time Control Register |  |  |  | 0x0000_0000 |



| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [24]    | <b>DTCKSEL</b>  | <p><b>Dead-time Clock Select (Write Protect)</b><br/>           0 = Dead-time clock source from TMRx_PWMCLK without counter clock prescale.<br/>           1 = Dead-time clock source from TMRx_PWMCLK with counter clock prescale.<br/> <b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.</p>                                                                                                                                                                                              |
| [23:17] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [16]    | <b>DTEN</b>     | <p><b>Enable Dead-time Insertion for PWMx_CH0 and PWMx_CH1 (Write Protect)</b><br/>           Dead-time insertion function is only active when PWM complementary mode is enabled. If dead-time insertion is inactive, the outputs of PWMx_CH0 and PWMx_CH1 are complementary without any delay.<br/>           0 = Dead-time insertion Disabled on the pin pair.<br/>           1 = Dead-time insertion Enabled on the pin pair.<br/> <b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.</p> |
| [15:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [11:0]  | <b>DTCNT</b>    | <p><b>Dead-time Counter (Write Protect)</b><br/>           The dead-time can be calculated from the following two formulas:<br/> <math>\text{Dead-time} = (\text{DTCNT}[11:0] + 1) * \text{TMRx_PWMCLK}</math>, if DTCKSEL is 0.<br/> <math>\text{Dead-time} = (\text{DTCNT}[11:0] + 1) * \text{TMRx_PWMCLK} * (\text{CLKPSC} + 1)</math>, if DTCKSEL is 1.<br/> <b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.</p>                                                                      |

**Timer PWM Counter Register (TIMERx PWM\_CNT)**

| Register       | Offset         | R/W | Description                 | Reset Value |
|----------------|----------------|-----|-----------------------------|-------------|
| TIMER0_PWM_CNT | TMR01_BA+0x5C  | R   | Timer0 PWM Counter Register | 0x0000_0000 |
| TIMER1_PWM_CNT | TMR01_BA+0x15C | R   | Timer1 PWM Counter Register | 0x0000_0000 |
| TIMER2_PWM_CNT | TMR23_BA+0x5C  | R   | Timer2 PWM Counter Register | 0x0000_0000 |
| TIMER3_PWM_CNT | TMR23_BA+0x15C | R   | Timer3 PWM Counter Register | 0x0000_0000 |

|          |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| Reserved |    |    |    |    |    |    |    |
| 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |    |    |    |    |    |    |    |
| 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        | <b>PWM Counter Direction Indicator Flag (Read Only)</b><br>0 = Counter is active in down count.<br>1 = Counter is active up count. |
| [15:0]  | CNT         | <b>PWM Counter Value Register (Read Only)</b><br>User can monitor CNT to know the current counter value in 16-bit period counter.  |

**Timer PWM Output Mask Enable Register (TIMERx\_PWMMSKEN)**

| Register                | Offset         | R/W | Description                            |  |  |  | Reset Value |
|-------------------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| <b>TIMER0_PWM_MSKEN</b> | TMR01_BA+0x60  | R/W | Timer0 PWM Output Mask Enable Register |  |  |  | 0x0000_0000 |
| <b>TIMER1_PWM_MSKEN</b> | TMR01_BA+0x160 | R/W | Timer1 PWM Output Mask Enable Register |  |  |  | 0x0000_0000 |
| <b>TIMER2_PWM_MSKEN</b> | TMR23_BA+0x60  | R/W | Timer2 PWM Output Mask Enable Register |  |  |  | 0x0000_0000 |
| <b>TIMER3_PWM_MSKEN</b> | TMR23_BA+0x160 | R/W | Timer3 PWM Output Mask Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description   |                                                                                                                                                                                                                                                                                                      |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                            |
| [1]    | <b>MSKEN1</b> | <p><b>PWMx_CH1 Output Mask Enable Bit</b></p> <p>The PWMx_CH1 output signal will be masked when this bit is enabled. The PWMx_CH1 will output MSKDAT1 (TIMER_PWMMSK[1]) data.</p> <p>0 = PWMx_CH1 output signal is non-masked.<br/>1 = PWMx_CH1 output signal is masked and output MSKDAT1 data.</p> |
| [0]    | <b>MSKEN0</b> | <p><b>PWMx_CH0 Output Mask Enable Bit</b></p> <p>The PWMx_CH0 output signal will be masked when this bit is enabled. The PWMx_CH0 will output MSKDAT0 (TIMER_PWMMSK[0]) data.</p> <p>0 = PWMx_CH0 output signal is non-masked.<br/>1 = PWMx_CH0 output signal is masked and output MSKDAT0 data.</p> |

**Timer PWM Output Mask Data Control Register (TIMERx\_PWMMSK)**

| Register              | Offset         | R/W | Description                                  |  |  |  | Reset Value |
|-----------------------|----------------|-----|----------------------------------------------|--|--|--|-------------|
| <b>TIMER0_PWM_MSK</b> | TMR01_BA+0x64  | R/W | Timer0 PWM Output Mask Data Control Register |  |  |  | 0x0000_0000 |
| <b>TIMER1_PWM_MSK</b> | TMR01_BA+0x164 | R/W | Timer1 PWM Output Mask Data Control Register |  |  |  | 0x0000_0000 |
| <b>TIMER2_PWM_MSK</b> | TMR23_BA+0x64  | R/W | Timer2 PWM Output Mask Data Control Register |  |  |  | 0x0000_0000 |
| <b>TIMER3_PWM_MSK</b> | TMR23_BA+0x164 | R/W | Timer3 PWM Output Mask Data Control Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                     |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                           |
| [1]    | <b>MSKDAT1</b>  | <p><b>PWMx_CH1 Output Mask Data Control Bit</b></p> <p>This bit is used to control the output state of PWMx_CH1 pin when PWMx_CH1 output mask function is enabled (MSKEN1 = 1).</p> <p>0 = Output logic Low to PWMx_CH1.<br/>1 = Output logic High to PWMx_CH1.</p> |
| [0]    | <b>MSKDAT0</b>  | <p><b>PWMx_CH0 Output Mask Data Control Bit</b></p> <p>This bit is used to control the output state of PWMx_CH0 pin when PWMx_CH0 output mask function is enabled (MSKEN0 = 1).</p> <p>0 = Output logic Low to PWMx_CH0.<br/>1 = Output logic High to PWMx_CH0.</p> |

**Timer PWM Brake Pin Noise Filter Register (TIMERx PWMBNF)**

| Register              | Offset         | R/W | Description                                |  |  |  | Reset Value |
|-----------------------|----------------|-----|--------------------------------------------|--|--|--|-------------|
| <b>TIMER0_PWM_BNF</b> | TMR01_BA+0x68  | R/W | Timer0 PWM Brake Pin Noise Filter Register |  |  |  | 0x0000_0000 |
| <b>TIMER1_PWM_BNF</b> | TMR01_BA+0x168 | R/W | Timer1 PWM Brake Pin Noise Filter Register |  |  |  | 0x0000_0000 |
| <b>TIMER2_PWM_BNF</b> | TMR23_BA+0x68  | R/W | Timer2 PWM Brake Pin Noise Filter Register |  |  |  | 0x0000_0000 |
| <b>TIMER3_PWM_BNF</b> | TMR23_BA+0x168 | R/W | Timer3 PWM Brake Pin Noise Filter Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                              |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                    |
| [17:16] | <b>BKPINSRC</b> | <b>Brake Pin Source Select</b><br>00 = Brake pin source comes from PWM0_BRAKE0 pin.<br>01 = Brake pin source comes from PWM0_BRAKE1 pin.<br>10 = Brake pin source comes from PWM1_BRAKE0 pin.<br>11 = Brake pin source comes from PWM1_BRAKE1 pin.                                                                                           |
| [15:8]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                    |
| [7]     | <b>BRKPINV</b>  | <b>Brake Pin Detection Control Bit</b><br>0 = Brake pin event will be detected if PWMx_BRAKEy pin status transfer from low to high in edge-detect, or pin status is high in level-detect.<br>1 = Brake pin event will be detected if PWMx_BRAKEy pin status transfer from high to low in edge-detect, or pin status is low in level-detect . |
| [6:4]   | <b>BRKFCNT</b>  | <b>Brake Pin Noise Filter Count</b><br>The fields is used to control the active noise filter sample time.<br>Once noise filter sample time = (Period time of BRKDBCS) * BRKFCNT.                                                                                                                                                             |
| [3:1]   | <b>BRKNFSEL</b> | <b>Brake Pin Noise Filter Clock Selection</b><br>000 = Noise filter clock is PCLKx.<br>001 = Noise filter clock is PCLKx/2.<br>010 = Noise filter clock is PCLKx/4.<br>011 = Noise filter clock is PCLKx/8.<br>100 = Noise filter clock is PCLKx/16.                                                                                         |

|     |                |                                                                                                                                                         |
|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                | 101 = Noise filter clock is PCLKx/32.<br>110 = Noise filter clock is PCLKx/64.<br>111 = Noise filter clock is PCLKx/128.                                |
| [0] | <b>BRKNFEN</b> | <b>Brake Pin Noise Filter Enable Bit</b><br>0 = Pin noise filter detect of PWMx_BRAKEy Disabled.<br>1 = Pin noise filter detect of PWMx_BRAKEy Enabled. |

**Timer PWM System Fail Brake Control Register (TIMERx PWMFAILBRK)**

| Register           | Offset         | R/W | Description                                   |  |  |  | Reset Value |
|--------------------|----------------|-----|-----------------------------------------------|--|--|--|-------------|
| TIMER0_PWM_FAILBRK | TMR01_BA+0x6C  | R/W | Timer0 PWM System Fail Brake Control Register |  |  |  | 0x0000_0000 |
| TIMER1_PWM_FAILBRK | TMR01_BA+0x16C | R/W | Timer1 PWM System Fail Brake Control Register |  |  |  | 0x0000_0000 |
| TIMER2_PWM_FAILBRK | TMR23_BA+0x6C  | R/W | Timer2 PWM System Fail Brake Control Register |  |  |  | 0x0000_0000 |
| TIMER3_PWM_FAILBRK | TMR23_BA+0x16C | R/W | Timer3 PWM System Fail Brake Control Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                 |
| [3]    | CORBRKEN    | <b>Core Lockup Detection Trigger PWM Brake Function Enable Bit</b><br>0 = Brake Function triggered by core lockup event Disabled.<br>1 = Brake Function triggered by core lockup event Enabled.                           |
| [2]    | RAMBRKEN    | <b>SRAM Parity Error Detection Trigger PWM Brake Function Enable Bit</b><br>0 = Brake Function triggered by SRAM parity error detection Disabled.<br>1 = Brake Function triggered by SRAM parity error detection Enabled. |
| [1]    | BODBRKEN    | <b>Brown-out Detection Trigger PWM Brake Function Enable Bit</b><br>0 = Brake Function triggered by BOD event Disabled.<br>1 = Brake Function triggered by BOD event Enabled.                                             |
| [0]    | CSSBRKEN    | <b>Clock Security System Detection Trigger PWM Brake Function Enable Bit</b><br>0 = Brake Function triggered by clock fail detection Disabled.<br>1 = Brake Function triggered by clock fail detection Enabled.           |

**Timer PWM Brake Control Register (TIMERx\_PWMBRKCTL)**

| Register         | Offset         | R/W | Description                       |  |  | Reset Value |
|------------------|----------------|-----|-----------------------------------|--|--|-------------|
| TIMER0_PWMBRKCTL | TMR01_BA+0x70  | R/W | Timer0 PWM Brake Control Register |  |  | 0x0000_0000 |
| TIMER1_PWMBRKCTL | TMR01_BA+0x170 | R/W | Timer1 PWM Brake Control Register |  |  | 0x0000_0000 |
| TIMER2_PWMBRKCTL | TMR23_BA+0x70  | R/W | Timer2 PWM Brake Control Register |  |  | 0x0000_0000 |
| TIMER3_PWMBRKCTL | TMR23_BA+0x170 | R/W | Timer3 PWM Brake Control Register |  |  | 0x0000_0000 |

|          |          |    |         |          |    |          |          |
|----------|----------|----|---------|----------|----|----------|----------|
| 31       | 30       | 29 | 28      | 27       | 26 | 25       | 24       |
| Reserved |          |    |         |          |    |          |          |
| 23       | 22       | 21 | 20      | 19       | 18 | 17       | 16       |
| Reserved |          |    |         | BRKAODD  |    | BRKAEVEN |          |
| 15       | 14       | 13 | 12      | 11       | 10 | 9        | 8        |
| SYSLBEN  | Reserved |    | BRKPLEN | Reserved |    | CPO1LBEN | CPO0LBEN |
| 7        | 6        | 5  | 4       | 3        | 2  | 1        | 0        |
| SYSEBEN  | Reserved |    | BRKPEEN | Reserved |    | CPO1EBEN | CPO0EBEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [19:18] | BRKAODD     | <b>PWM Brake Action Select for PWMx_CH1 (Write Protect)</b><br>00 = PWMx_BRAKEy brake event will not affect PWMx_CH1 output.<br>01 = PWMx_CH1 output tri-state when PWMx_BRAKEy brake event happened.<br>10 = PWMx_CH1 output low level when PWMx_BRAKEy brake event happened.<br>11 = PWMx_CH1 output high level when PWMx_BRAKEy brake event happened.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [17:16] | BRKAEVEN    | <b>PWM Brake Action Select for PWMx_CH0 (Write Protect)</b><br>00 = PWMx_BRAKEy brake event will not affect PWMx_CH0 output.<br>01 = PWMx_CH0 output tri-state when PWMx_BRAKEy brake event happened.<br>10 = PWMx_CH0 output low level when PWMx_BRAKEy brake event happened.<br>11 = PWMx_CH0 output high level when PWMx_BRAKEy brake event happened.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [15]    | SYSLBEN     | <b>Enable System Fail As Level-detect Brake Source (Write Protect)</b><br>0 = System fail condition as level-detect brake source Disabled.<br>1 = System fail condition as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                            |
| [14:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [12]    | BRKPLEN     | <b>Enable TM_BRAKEy Pin As Level-detect Brake Source (Write Protect)</b><br>0 = PWMx_BRAKEy pin event as level-detect brake source Disabled.                                                                                                                                                                                                                                                                                         |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 1 = PWMx_BRAKEy pin event as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                                                        |
| [11:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                          |
| [9]     | <b>CPO1LBEN</b> | <b>Enable Internal ACMP1_O Digital Output As Level-detect Brake Source (Write Protect)</b><br>0 = Internal ACMP1_O signal as level-detect brake source Disabled.<br>1 = Internal ACMP1_O signal as level-detect brake source Enabled.<br><b>Note1:</b> Only internal ACMP1_O signal from low to high will be detected as brake event.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [8]     | <b>CPO0LBEN</b> | <b>Enable Internal ACMP0_O Digital Output As Level-detect Brake Source (Write Protect)</b><br>0 = Internal ACMP0_O signal as level-detect brake source Disabled.<br>1 = Internal ACMP0_O signal as level-detect brake source Enabled.<br><b>Note1:</b> Only internal ACMP0_O signal from low to high will be detected as brake event.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [7]     | <b>SYSEBEN</b>  | <b>Enable System Fail As Edge-detect Brake Source (Write Protect)</b><br>0 = System fail condition as edge-detect brake source Disabled.<br>1 = System fail condition as edge-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                             |
| [6:5]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                          |
| [4]     | <b>BRKPEEN</b>  | <b>Enable TM_BRAKEy Pin As Edge-detect Brake Source (Write Protect)</b><br>0 = PWMx_BRAKEy pin event as edge-detect brake source Disabled.<br>1 = PWMx_BRAKEy pin event as edge-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                           |
| [3:2]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                          |
| [1]     | <b>CPO1EBEN</b> | <b>Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)</b><br>0 = Internal ACMP1_O signal as edge-detect brake source Disabled.<br>1 = Internal ACMP1_O signal as edge-detect brake source Enabled.<br><b>Note1:</b> Only internal ACMP1_O signal from low to high will be detected as brake event.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |
| [0]     | <b>CPO0EBEN</b> | <b>Enable Internal ACMP0_O Digital Output As Edge-detect Brake Source (Write Protect)</b><br>0 = Internal ACMP0_O signal as edge-detect brake source Disabled.<br>1 = Internal ACMP0_O signal as edge-detect brake source Enabled.<br><b>Note1:</b> Only internal ACMP0_O signal from low to high will be detected as brake event.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |

**Timer PWM Pin Output Polar Control Register (TIMERx PWMPOLCTL)**

| Register          | Offset         | R/W | Description                                  |  |  |  | Reset Value |
|-------------------|----------------|-----|----------------------------------------------|--|--|--|-------------|
| TIMER0_PWM_POLCTL | TMR01_BA+0x74  | R/W | Timer0 PWM Pin Output Polar Control Register |  |  |  | 0x0000_0000 |
| TIMER1_PWM_POLCTL | TMR01_BA+0x174 | R/W | Timer1 PWM Pin Output Polar Control Register |  |  |  | 0x0000_0000 |
| TIMER2_PWM_POLCTL | TMR23_BA+0x74  | R/W | Timer2 PWM Pin Output Polar Control Register |  |  |  | 0x0000_0000 |
| TIMER3_PWM_POLCTL | TMR23_BA+0x174 | R/W | Timer3 PWM Pin Output Polar Control Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                        |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                              |
| [1]    | PINV1       | <b>PWMx_CH1 Output Pin Polar Control Bit</b><br>The bit is used to control polarity state of PWMx_CH1 output pin.<br>0 = PWMx_CH1 output pin polar inverse Disabled.<br>1 = PWMx_CH1 output pin polar inverse Enabled. |
| [0]    | PINV0       | <b>PWMx_CH0 Output Pin Polar Control Bit</b><br>The bit is used to control polarity state of PWMx_CH0 output pin.<br>0 = PWMx_CH0 output pin polar inverse Disabled.<br>1 = PWMx_CH0 output pin polar inverse Enabled. |

**Timer PWM Pin Output Enable Register (TIMERx\_PWMPOEN)**

| Register           | Offset         | R/W | Description                           |  |  |  | Reset Value |
|--------------------|----------------|-----|---------------------------------------|--|--|--|-------------|
| TIMER0_PWM<br>POEN | TMR01_BA+0x78  | R/W | Timer0 PWM Pin Output Enable Register |  |  |  | 0x0000_0000 |
| TIMER1_PWM<br>POEN | TMR01_BA+0x178 | R/W | Timer1 PWM Pin Output Enable Register |  |  |  | 0x0000_0000 |
| TIMER2_PWM<br>POEN | TMR23_BA+0x78  | R/W | Timer2 PWM Pin Output Enable Register |  |  |  | 0x0000_0000 |
| TIMER3_PWM<br>POEN | TMR23_BA+0x178 | R/W | Timer3 PWM Pin Output Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                        |
| [1]    | POEN1       | <b>PWMx_CH1 Output Pin Enable Bit</b><br>0 = PWMx_CH1 pin at tri-state mode.<br>1 = PWMx_CH1 pin in output mode. |
| [0]    | POENO       | <b>PWMx_CH0 Output Pin Enable Bit</b><br>0 = PWMx_CH0 pin at tri-state mode.<br>1 = PWMx_CH0 pin in output mode. |

**Timer PWM Software Trigger Brake Control Register (TIMERx\_PWM\_SWBRK)**

| Register         | Offset         | R/W | Description                                        |  |  |  | Reset Value |
|------------------|----------------|-----|----------------------------------------------------|--|--|--|-------------|
| TIMER0_PWM_SWBRK | TMR01_BA+0x7C  | W   | Timer0 PWM Software Trigger Brake Control Register |  |  |  | 0x0000_0000 |
| TIMER1_PWM_SWBRK | TMR01_BA+0x17C | W   | Timer1 PWM Software Trigger Brake Control Register |  |  |  | 0x0000_0000 |
| TIMER2_PWM_SWBRK | TMR23_BA+0x7C  | W   | Timer2 PWM Software Trigger Brake Control Register |  |  |  | 0x0000_0000 |
| TIMER3_PWM_SWBRK | TMR23_BA+0x17C | W   | Timer3 PWM Software Trigger Brake Control Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [8]    | BRKLTRG     | <b>Software Trigger Level-detect Brake Source (Write Only) (Write Protect)</b><br>Write 1 to this bit will trigger PWM level-detect brake source, then BRKLIF0 and BRKLIF1 will set to 1 automatically in TIMERx_PWMINTSTS1 register.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [0]    | BRKETRG     | <b>Software Trigger Edge-detect Brake Source (Write Only) (Write Protect)</b><br>Write 1 to this bit will trigger PWM edge-detect brake source, then BRKEIF0 and BRKEIF1 will set to 1 automatically in TIMERx_PWMINTSTS1 register.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.   |

**Timer PWM Interrupt Enable Register 0 (TIMERx PWMINTEN0)**

| Register                | Offset         | R/W | Description                            |  |  |  | Reset Value |
|-------------------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| <b>TIMER0_PWMINTENO</b> | TMR01_BA+0x80  | R/W | Timer0 PWM Interrupt Enable Register 0 |  |  |  | 0x0000_0000 |
| <b>TIMER1_PWMINTENO</b> | TMR01_BA+0x180 | R/W | Timer1 PWM Interrupt Enable Register 0 |  |  |  | 0x0000_0000 |
| <b>TIMER2_PWMINTENO</b> | TMR23_BA+0x80  | R/W | Timer2 PWM Interrupt Enable Register 0 |  |  |  | 0x0000_0000 |
| <b>TIMER3_PWMINTENO</b> | TMR23_BA+0x180 | R/W | Timer3 PWM Interrupt Enable Register 0 |  |  |  | 0x0000_0000 |

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

| Bits   | Description    |                                                                                                                                                                                                                               |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved       | Reserved.                                                                                                                                                                                                                     |
| [3]    | <b>CMPDIEN</b> | <b>PWM Compare Down Count Interrupt Enable Bit</b><br>0 = Compare down count interrupt Disabled.<br>1 = Compare down count interrupt Enabled.                                                                                 |
| [2]    | <b>CMPUIEN</b> | <b>PWM Compare Up Count Interrupt Enable Bit</b><br>0 = Compare up count interrupt Disabled.<br>1 = Compare up count interrupt Enabled.                                                                                       |
| [1]    | <b>PIEN</b>    | <b>PWM Period Point Interrupt Enable Bit</b><br>0 = Period point interrupt Disabled.<br>1 = Period point interrupt Enabled.<br><b>Note:</b> In up-down count type, period point means the center point of current PWM period. |
| [0]    | <b>ZIEN</b>    | <b>PWM Zero Point Interrupt Enable Bit</b><br>0 = Zero point interrupt Disabled.<br>1 = Zero point interrupt Enabled.                                                                                                         |

**Timer PWM Interrupt Enable Register 1 (TIMERx PWMINTEN1)**

| Register                | Offset         | R/W | Description                            |  |  |  | Reset Value |
|-------------------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| <b>TIMER0_PWMINTEN1</b> | TMR01_BA+0x84  | R/W | Timer0 PWM Interrupt Enable Register 1 |  |  |  | 0x0000_0000 |
| <b>TIMER1_PWMINTEN1</b> | TMR01_BA+0x184 | R/W | Timer1 PWM Interrupt Enable Register 1 |  |  |  | 0x0000_0000 |
| <b>TIMER2_PWMINTEN1</b> | TMR23_BA+0x84  | R/W | Timer2 PWM Interrupt Enable Register 1 |  |  |  | 0x0000_0000 |
| <b>TIMER3_PWMINTEN1</b> | TMR23_BA+0x184 | R/W | Timer3 PWM Interrupt Enable Register 1 |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                   |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                         |
| [8]    | <b>BRKLIEN</b>  | <b>PWM Level-detect Brake Interrupt Enable Bit (Write Protect)</b><br>0 = PWM level-detect brake interrupt Disabled.<br>1 = PWM level-detect brake interrupt Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:1]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                         |
| [0]    | <b>BRKEIEN</b>  | <b>PWM Edge-detect Brake Interrupt Enable Bit (Write Protect)</b><br>0 = PWM edge-detect brake interrupt Disabled.<br>1 = PWM edge-detect brake interrupt Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |

**Timer PWM Interrupt Status Register 0 (TIMERx\_PWMINTSTS0)**

| Register                 | Offset         | R/W | Description                            |  |  |  | Reset Value |
|--------------------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| <b>TIMER0_PWMINTSTS0</b> | TMR01_BA+0x88  | R/W | Timer0 PWM Interrupt Status Register 0 |  |  |  | 0x0000_0000 |
| <b>TIMER1_PWMINTSTS0</b> | TMR01_BA+0x188 | R/W | Timer1 PWM Interrupt Status Register 0 |  |  |  | 0x0000_0000 |
| <b>TIMER2_PWMINTSTS0</b> | TMR23_BA+0x88  | R/W | Timer2 PWM Interrupt Status Register 0 |  |  |  | 0x0000_0000 |
| <b>TIMER3_PWMINTSTS0</b> | TMR23_BA+0x188 | R/W | Timer3 PWM Interrupt Status Register 0 |  |  |  | 0x0000_0000 |

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

| Bits   | Description   |                                                                                                                                                                                                                                                                                                                                    |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                          |
| [3]    | <b>CMPDIF</b> | <p><b>PWM Compare Down Count Interrupt Flag</b><br/>           This bit is set by hardware when TIMERx_PWM counter in down count direction and reaches CMP.<br/> <b>Note1:</b> If CMP equal to PERIOD, there is no CMPDIF flag in down count type.<br/> <b>Note2:</b> This bit is cleared by writing 1 to it.</p>                  |
| [2]    | <b>CMPUIF</b> | <p><b>PWM Compare Up Count Interrupt Flag</b><br/>           This bit is set by hardware when TIMERx_PWM counter in up count direction and reaches CMP.<br/> <b>Note1:</b> If CMP equal to PERIOD, there is no CMPUIF flag in up count type and up-down count type.<br/> <b>Note2:</b> This bit is cleared by writing 1 to it.</p> |
| [1]    | <b>PIF</b>    | <p><b>PWM Period Point Interrupt Flag</b><br/>           This bit is set by hardware when TIMERx_PWM counter reaches PERIOD.<br/> <b>Note1:</b> In up-down count type, PIF flag means the center point flag of current PWM period.<br/> <b>Note2:</b> This bit is cleared by writing 1 to it.</p>                                  |
| [0]    | <b>ZIF</b>    | <p><b>PWM Zero Point Interrupt Flag</b><br/>           This bit is set by hardware when TIMERx_PWM counter reaches 0.<br/> <b>Note:</b> This bit is cleared by writing 1 to it.</p>                                                                                                                                                |

**Timer PWM Interrupt Status Register 1 (TIMERx\_PWMINTSTS1)**

| Register          | Offset         | R/W | Description                            |  |  |  | Reset Value |
|-------------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| TIMER0_PWMINTSTS1 | TMR01_BA+0x8C  | R/W | Timer0 PWM Interrupt Status Register 1 |  |  |  | 0x0000_0000 |
| TIMER1_PWMINTSTS1 | TMR01_BA+0x18C | R/W | Timer1 PWM Interrupt Status Register 1 |  |  |  | 0x0000_0000 |
| TIMER2_PWMINTSTS1 | TMR23_BA+0x8C  | R/W | Timer2 PWM Interrupt Status Register 1 |  |  |  | 0x0000_0000 |
| TIMER3_PWMINTSTS1 | TMR23_BA+0x18C | R/W | Timer3 PWM Interrupt Status Register 1 |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [25]    | BRKLSTS1    | <p><b>Level-detect Brake Status of PWMx_CH1 (Read Only)</b></p> <p>0 = PWMx_CH1 level-detect brake state is released.<br/>1 = PWMx_CH1 at level-detect brake state.</p> <p><b>Note:</b> If TIMERx_PWM level-detect brake source has released, both PWMx_CH0 and PWMx_CH1 will release brake state when current PWM period finished and resume PWMx_CH0 and PWMx_CH1 output waveform start from next full PWM period.</p> |
| [24]    | BRKLSTS0    | <p><b>Level-detect Brake Status of PWMx_CH0 (Read Only)</b></p> <p>0 = PWMx_CH0 level-detect brake state is released.<br/>1 = PWMx_CH0 at level-detect brake state.</p> <p><b>Note:</b> If TIMERx_PWM level-detect brake source has released, both PWMx_CH0 and PWMx_CH1 will release brake state when current PWM period finished and resume PWMx_CH0 and PWMx_CH1 output waveform start from next full PWM period.</p> |
| [23:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [17]    | BRKESTS1    | <p><b>Edge-detect Brake Status of PWMx_CH1 (Read Only)</b></p> <p>0 = PWMx_CH1 edge-detect brake state is released.<br/>1 = PWMx_CH1 at edge-detect brake state.</p> <p><b>Note:</b> User can set BRKEIF1 1 to clear BRKEIF1 flag and PWMx_CH1 will release brake state when current PWM period finished and resume PWMx_CH1 output waveform start from next full PWM period.</p>                                        |
| [16]    | BRKESTS0    | <p><b>Edge -detect Brake Status of PWMx_CH0 (Read Only)</b></p> <p>0 = PWMx_CH0 edge-detect brake state is released.</p>                                                                                                                                                                                                                                                                                                 |

|         |                 |                                                                                                                                                                                                                                                                                                                         |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 1 = PWMx_CH0 at edge-detect brake state.<br><br><b>Note:</b> User can set BRKEIF0 1 to clear BRKEIF0 flag and PWMx_CH0 will release brake state when current PWM period finished and resume PWMx_CH0 output waveform start from next full PWM period.                                                                   |
| [15:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                               |
| [9]     | <b>BRKLIF1</b>  | <b>Level-detect Brake Interrupt Flag on PWMx_CH1 (Write Protect)</b><br>0 = PWMx_CH1 level-detect brake event do not happened.<br>1 = PWMx_CH1 level-detect brake event happened.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [8]     | <b>BRKLIF0</b>  | <b>Level-detect Brake Interrupt Flag on PWMx_CH0 (Write Protect)</b><br>0 = PWMx_CH0 level-detect brake event do not happened.<br>1 = PWMx_CH0 level-detect brake event happened.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:2]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                               |
| [1]     | <b>BRKEIF1</b>  | <b>Edge-detect Brake Interrupt Flag PWMx_CH1 (Write Protect)</b><br>0 = PWMx_CH1 edge-detect brake event do not happened.<br>1 = PWMx_CH1 edge-detect brake event happened.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register.       |
| [0]     | <b>BRKEIF0</b>  | <b>Edge-detect Brake Interrupt Flag on PWMx_CH0 (Write Protect)</b><br>0 = PWMx_CH0 edge-detect brake event do not happened.<br>1 = PWMx_CH0 edge-detect brake event happened.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |

**Timer PWM ADC Trigger Control Register (TIMERx\_PWMADCTS)**

| Register        | Offset         | R/W | Description                                   |  |  |  | Reset Value |
|-----------------|----------------|-----|-----------------------------------------------|--|--|--|-------------|
| TIMER0_PWMADCTS | TMR01_BA+0x90  | R/W | Timer0 PWM ADC Trigger Source Select Register |  |  |  | 0x0000_0000 |
| TIMER1_PWMADCTS | TMR01_BA+0x190 | R/W | Timer1 PWM ADC Trigger Source Select Register |  |  |  | 0x0000_0000 |
| TIMER2_PWMADCTS | TMR23_BA+0x90  | R/W | Timer2 PWM ADC Trigger Source Select Register |  |  |  | 0x0000_0000 |
| TIMER3_PWMADCTS | TMR23_BA+0x190 | R/W | Timer3 PWM ADC Trigger Source Select Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [7]    | TRGEN       | <b>PWM Counter Event Trigger ADC Conversion Enable Bit</b><br>0 = PWM counter event trigger ADC conversion Disabled.<br>1 = PWM counter event trigger ADC conversion Enabled.                                                                                                                                                                                                                                            |
| [6:3]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [2:0]  | TRGSEL      | <b>PWM Counter Event Source Select to Trigger EADC Conversion</b><br>000 = Trigger EADC conversion at zero point (ZIF).<br>001 = Trigger EADC conversion at period point (PIF).<br>010 = Trigger EADC conversion at zero or period point (ZIF or PIF).<br>011 = Trigger EADC conversion at compare up count point (CMPUIF).<br>100 = Trigger EADC conversion at compare down count point (CMPDIF).<br>Others = Reserved. |

**Timer PWM Synchronous Control Register (TIMERx PWMSCTL)**

| Register       | Offset         | R/W | Description                             | Reset Value |
|----------------|----------------|-----|-----------------------------------------|-------------|
| TIMER0_PWMSCTL | TMR01_BA+0x94  | R/W | Timer0 PWM Synchronous Control Register | 0x0000_0000 |
| TIMER1_PWMSCTL | TMR01_BA+0x194 | R/W | Timer1 PWM Synchronous Control Register | 0x0000_0000 |
| TIMER2_PWMSCTL | TMR23_BA+0x94  | R/W | Timer2 PWM Synchronous Control Register | 0x0000_0000 |
| TIMER3_PWMSCTL | TMR23_BA+0x194 | R/W | Timer3 PWM Synchronous Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [8]    | SYNCSRC     | <p><b>PWM Synchronous Counter Start/Clear Source Select</b><br/>           0 = Counter synchronous start/clear by trigger TIMER0_PWMSTRG STRGEN.<br/>           1 = Counter synchronous start/clear by trigger TIMER2_PWMSTRG STRGEN.</p> <p><b>Note1:</b> If TIMER0/1/2/3 PWM counter synchronous source are from TIMER0, TIMER0_PWMSCTL[8], TIMER1_PWMSCTL[8], TIMER2_PWMSCTL[8] and TIMER3_PWMSCTL[8] should be 0.</p> <p><b>Note2:</b> If TIMER0/1/ PWM counter synchronous source are from TIMER0, TIMER0_PWMSCTL[8] and TIMER1_PWMSCTL[8] should be set 0, and TIMER2/3/ PWM counter synchronous source are from TIMER2, TIME2_PWMSCTL[8] and TIMER3_PWMSCTL[8] should be set 1.</p> |
| [7:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [1:0]  | SYNCMODE    | <p><b>PWM Synchronous Mode Enable Select</b><br/>           00 = PWM synchronous function Disabled.<br/>           01 = PWM synchronous counter start function Enabled.<br/>           10 = Reserved.<br/>           11 = PWM synchronous counter clear function Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                              |

**Timer PWM Synchronous Trigger Register (TIMERx\_PWMSTRG)**

| Register       | Offset        | R/W | Description                             |  |  |  | Reset Value |
|----------------|---------------|-----|-----------------------------------------|--|--|--|-------------|
| TIMER0_PWMSTRG | TMR01_BA+0x98 | W   | Timer0 PWM Synchronous Trigger Register |  |  |  | 0x0000_0000 |
| TIMER2_PWMSTRG | TMR23_BA+0x98 | W   | Timer2 PWM Synchronous Trigger Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                               |
| [0]    | STRGEN      | <p><b>PWM Counter Synchronous Trigger Enable Bit (Write Only)</b></p> <p>PMW counter synchronous function is used to make selected PWM channels (include TIMER0/1/2/3 PWM, TIMER0/1 PWM and TIMER2/3 PWM) start counting or clear counter at the same time according to TIMERx_PWMCTL setting.</p> <p><b>Note:</b> This bit is only available in TIMER0 and TIMER2.</p> |

**Timer PWM Status Register (TIMERx\_PWMSTATUS)**

| Register          | Offset         | R/W | Description                | Reset Value |
|-------------------|----------------|-----|----------------------------|-------------|
| TIMER0_PWM STATUS | TMR01_BA+0x9C  | R/W | Timer0 PWM Status Register | 0x0000_0000 |
| TIMER1_PWM STATUS | TMR01_BA+0x19C | R/W | Timer1 PWM Status Register | 0x0000_0000 |
| TIMER2_PWM STATUS | TMR23_BA+0x9C  | R/W | Timer2 PWM Status Register | 0x0000_0000 |
| TIMER3_PWM STATUS | TMR23_BA+0x19C | R/W | Timer3 PWM Status Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                      |
| [16]    | EADCTRGF    | <b>Trigger EADC Start Conversion Flag</b><br>0 = PWM counter event trigger EADC start conversion is not occurred.<br>1 = PWM counter event trigger EADC start conversion has occurred.<br><b>Note:</b> This bit is cleared by writing 1 to it. |
| [15:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                      |
| [0]     | CNTMAXF     | <b>PWM Counter Equal to 0xFFFF Flag</b><br>0 = The PWM counter value never reached its maximum value 0xFFFF.<br>1 = The PWM counter value has reached its maximum value.<br><b>Note:</b> This bit is cleared by writing 1 to it.               |

**Timer PWM Period Buffer Register (TIMERx PWMPBUF)**

| Register        | Offset         | R/W | Description                       | Reset Value |
|-----------------|----------------|-----|-----------------------------------|-------------|
| TIMER0_PWM_PBUF | TMR01_BA+0xA0  | R   | Timer0 PWM Period Buffer Register | 0x0000_0000 |
| TIMER1_PWM_PBUF | TMR01_BA+0x1A0 | R   | Timer1 PWM Period Buffer Register | 0x0000_0000 |
| TIMER2_PWM_PBUF | TMR23_BA+0xA0  | R   | Timer2 PWM Period Buffer Register | 0x0000_0000 |
| TIMER3_PWM_PBUF | TMR23_BA+0x1A0 | R   | Timer3 PWM Period Buffer 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  |
| PBUF     |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| PBUF     |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                        |
| [15:0]  | PBUF        | <b>PWM Period Buffer Register (Read Only)</b><br>Used as PERIOD active register. |

**Timer PWM Comparator Buffer Register (TIMERx PWMCMPPBUF)**

| Register          | Offset         | R/W | Description                           | Reset Value |
|-------------------|----------------|-----|---------------------------------------|-------------|
| TIMER0_PWM_CMPBUF | TMR01_BA+0xA4  | R   | Timer0 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER1_PWM_CMPBUF | TMR01_BA+0x1A4 | R   | Timer1 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER2_PWM_CMPBUF | TMR23_BA+0xA4  | R   | Timer2 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER3_PWM_CMPBUF | TMR23_BA+0x1A4 | R   | Timer3 PWM Comparator Buffer 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  |
| 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

- 18-bit free running up counter for WDT time-out interval
- Selectable time-out interval (24 ~ 218) and the time-out interval is 1.6 ms ~ 26.214 s if WDT\_CLK = 10 kHz.
- System kept in reset state for a period of  $(1 / \text{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 CWDTE[2:0] in Config0 register
- Supports WDT time-out wake-up function only if WDT clock source is selected as 10 kHz 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:** Chip can be woken up by WDT time-out interrupt signal generated only if WDT clock source is selected to 10 kHz oscillator.

**Note3:** The WDT reset delay period can be selected as 3/18/130/1026 WDT\_CLK.

### 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\_APBCLK0[0]).
  - Force enable WDT controller after chip powered on or reset in CWDTE[2:0]

(CWDTE[2] is Config0[31], CWDTE[1:0] is Config0[4:3])

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 18-bit free running up counter with programmable time-out intervals. Table 6.8-1 shows the WDT time-out interval period selection and Figure 6.8-3 shows the WDT time-out interval and reset period timing.

#### 6.8.5.1 WDT Time-out Interrupt

Setting WDTEN (WDTCR[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 (WDTCR[10:8]). When the WDT up counter reaches the TOUTSEL (WDTCR[10: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  $T_{RSTD}$  reset delay period follows the IF (WDT\_CTL[3]) is setting to 1. User should set RSTCNT (WDT\_CTL[0]) or set WDT\_RSTCNT to reset the 18-bit WDT up counter value to avoid generate WDT time-out reset signal before the  $T_{RSTD}$  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_{RSTD}$  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. Refer to Figure 6.8-3.  $T_{RST}$  reset period will keep last 63 WDT clocks then chip restart executing program from reset vector (0x0000\_0000). The RSTF (WDT\_CTL[2]) will keep 1 after WDT time-out resets the chip, user can check RSTF (WDT\_CTL[2]) by software to recognize the system has been reset by WDT time-out reset or not.

| TOUTSEL | Time-Out Interval Period<br>$T_{TIS}$ | Reset Delay Period<br>$T_{RSTD}$ |
|---------|---------------------------------------|----------------------------------|
| 000     | $2^4 * T_{WDT}$                       | $(3/18/130/1026) * T_{WDT}$      |
| 001     | $2^6 * T_{WDT}$                       | $(3/18/130/1026) * T_{WDT}$      |
| 010     | $2^8 * T_{WDT}$                       | $(3/18/130/1026) * T_{WDT}$      |
| 011     | $2^{10} * T_{WDT}$                    | $(3/18/130/1026) * T_{WDT}$      |
| 100     | $2^{12} * T_{WDT}$                    | $(3/18/130/1026) * T_{WDT}$      |
| 101     | $2^{14} * T_{WDT}$                    | $(3/18/130/1026) * T_{WDT}$      |
| 110     | $2^{16} * T_{WDT}$                    | $(3/18/130/1026) * T_{WDT}$      |
| 111     | $2^{18} * T_{WDT}$                    | $(3/18/130/1026) * T_{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 10 kHz 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 Power-down 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.

#### 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 |
|-----------------------------|-------------|-----|----------------------------------|-------------|
| <b>WDT Base Address:</b>    |             |     |                                  |             |
| <b>WDT_BA = 0x4004_0000</b> |             |     |                                  |             |
| <b>WDT_CTL</b>              | WDT_BA+0x00 | R/W | WDT Control Register             | 0x0000_0700 |
| <b>WDT_ALTCTL</b>           | WDT_BA+0x04 | R/W | WDT Alternative Control Register | 0x0000_0000 |
| <b>WDT_RSTCNT</b>           | WDT_BA+0x08 | W   | WDT Reset Counter Register       | 0x0000_0000 |

### 6.8.7 Register Description

#### WDT Control Register (WDT\_CTL)

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | ICEDEBUG    | <b>ICE Debug Mode Acknowledge Disable Bit (Write Protect)</b><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><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                  |
| [30]    | SYNC        | <b>WDT Enable Control SYNC Flag Indicator (Read Only)</b><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><b>Note:</b> Performing enable or disable WDTEN bit needs 2 * WDT_CLK period to become active.                                                       |
| [29:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [10:8]  | TOUTSEL     | <b>WDT Time-out Interval Selection (Write Protect)</b><br>These three bits select the time-out interval period for the WDT.<br>000 = $2^4 * WDT\_CLK$ .<br>001 = $2^6 * WDT\_CLK$ .<br>010 = $2^8 * WDT\_CLK$ .<br>011 = $2^{10} * WDT\_CLK$ .<br>100 = $2^{12} * WDT\_CLK$ .<br>101 = $2^{14} * WDT\_CLK$ .<br>110 = $2^{16} * WDT\_CLK$ .<br>111 = $2^{18} * WDT\_CLK$ .<br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register. |
| [7]     | WDTEN       | <b>WDT Enable Bit (Write Protect)</b>                                                                                                                                                                                                                                                                                                                                                                                                                      |

|     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | 0 = WDT Disabled (This action will reset the internal up counter value).<br>1 = WDT Enabled.<br><br><b>Note1:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note2:</b> If CWDTC[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  | <b>WDT Time-out Interrupt Enable Bit (Write Protect)</b><br><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><br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [5] | WKF    | <b>WDT Time-out Wake-up Flag (Write Protect)</b><br><br>This bit indicates the interrupt wake-up flag status of WDT<br>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><br><b>Note1:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note2:</b> This bit is cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                            |
| [4] | WKEN   | <b>WDT Time-out Wake-up Function Control (Write Protect)</b><br><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><br><b>Note1:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note2:</b> Chip can be woken up by WDT time-out interrupt signal generated only if WDT clock source is selected to 10 kHz internal low speed RC oscillator (LIRC) or LXT. |
| [3] | IF     | <b>WDT Time-out Interrupt Flag</b><br><br>This bit will set to 1 while WDT up counter value reaches the selected WDT time-out interval<br>0 = WDT time-out interrupt did not occur.<br>1 = WDT time-out interrupt occurred.<br><br><b>Note:</b> This bit is cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [2] | RSTF   | <b>WDT Time-out Reset Flag</b><br><br>This bit indicates the system has been reset by WDT time-out reset or not.<br>0 = WDT time-out reset did not occur.<br>1 = WDT time-out reset occurred.<br><br><b>Note:</b> This bit is cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [1] | RSTEN  | <b>WDT Time-out Reset Enable Bit (Write Protect)</b><br><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><br><b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                         |
| [0] | RSTCNT | <b>Reset WDT Up Counter (Write Protect)</b><br><br>0 = No effect.<br>1 = Reset the internal 18-bit WDT up counter value.<br><br><b>Note1:</b> This bit is write protected. Refer to the SYS_REGLCTL register.<br><b>Note2:</b> This bit will be automatically cleared by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

**WDT Alternative Control Register (WDT\_ALTCTL)**

| Register   | Offset      | R/W | Description                      |  |  |  |  | Reset Value |
|------------|-------------|-----|----------------------------------|--|--|--|--|-------------|
| WDT_ALTCTL | WDT_BA+0x04 | R/W | WDT Alternative Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [1:0]  | RSTDSEL     | <p><b>WDT Reset Delay Selection (Write Protect)</b></p> <p>When WDT time-out happened, user has a time named WDT Reset Delay Period to clear WDT counter by setting RSTCNT (WDT_CTL[0]) to prevent WDT time-out reset happened. User can select a suitable setting of RSTDSEL for different WDT Reset Delay Period.</p> <p>00 = WDT Reset Delay Period is 1026 * WDT_CLK.<br/>     01 = WDT Reset Delay Period is 130 * WDT_CLK.<br/>     10 = WDT Reset Delay Period is 18 * WDT_CLK.<br/>     11 = WDT Reset Delay Period is 3 * WDT_CLK.</p> <p><b>Note1:</b> This bit is write protected. Refer to the SYS_REGLCTL register.</p> <p><b>Note2:</b> This register will be reset to 0 if WDT time-out reset happened.</p> |

**WDT Reset Counter Register (WDT\_RSTCNT)**

| Register   | Offset      | R/W | Description                | Reset Value |
|------------|-------------|-----|----------------------------|-------------|
| WDT_RSTCNT | WDT_BA+0x08 | W   | WDT Reset Counter Register | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| [31:0] | RSTCNT      | <b>WDT Reset Counter Register</b><br>Writing 0x00005AA5 to this field will reset the internal 18-bit WDT up counter value to 0.<br><b>Note1:</b> Performing RSTCNT to reset counter needs 2 * WDT_CLK period to become active.<br><b>Note2:</b> RSTCNT (WDT_CTL[0]) bit is a write protected bit. RSTCNT (WDT_RSTCNT[31:0]) bits are not write protected. |  |  |  |  |  |  |  |

## 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\_APBCLK0[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 10 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 6.9-1.

| PSCSEL | Prescaler Value | Max. Time-Out Period   | Max. Time-Out Interval (WWDT_CLK=10 kHz) |
|--------|-----------------|------------------------|------------------------------------------|
| 0000   | 1               | $1 * 64 * T_{WWDT}$    | 6.4 ms                                   |
| 0001   | 2               | $2 * 64 * T_{WWDT}$    | 12.8 ms                                  |
| 0010   | 4               | $4 * 64 * T_{WWDT}$    | 25.6 ms                                  |
| 0011   | 8               | $8 * 64 * T_{WWDT}$    | 51.2 ms                                  |
| 0100   | 16              | $16 * 64 * T_{WWDT}$   | 102.4 ms                                 |
| 0101   | 32              | $32 * 64 * T_{WWDT}$   | 204.8 ms                                 |
| 0110   | 64              | $64 * 64 * T_{WWDT}$   | 409.6 ms                                 |
| 0111   | 128             | $128 * 64 * T_{WWDT}$  | 819.2 ms                                 |
| 1000   | 192             | $192 * 64 * T_{WWDT}$  | 1.2288 s                                 |
| 1001   | 256             | $256 * 64 * T_{WWDT}$  | 1.6384 s                                 |
| 1010   | 384             | $384 * 64 * T_{WWDT}$  | 2.4576 s                                 |
| 1011   | 512             | $512 * 64 * T_{WWDT}$  | 3.2768 s                                 |
| 1100   | 768             | $768 * 64 * T_{WWDT}$  | 4.9152 s                                 |
| 1101   | 1024            | $1024 * 64 * T_{WWDT}$ | 6.5536 s                                 |
| 1110   | 1536            | $1536 * 64 * T_{WWDT}$ | 9.8304 s                                 |
| 1111   | 2048            | $2048 * 64 * T_{WWDT}$ | 13.1072 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 0x3F 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 larger 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 &gt; CMPDAT

When WWDTIF (WWDT\_STATUS[0]) is generated, user must reload WWDT counter value to 0x3F by writing 0x00005AA5 to WWDT\_RLDCNT register, and also to prevent the WWDT counter value from reaching 0 and generate WWDT reset system signal to inform system reset. Figure 6.9-5 shows the waveform of WWDT reload counter when CNTDAT is less than CMPDAT and Figure 6.9-6 shows the WWDT generates reset system signal (WWDTRF) if user does not write 0x00005AA5 to WWDT\_RLD before WWDT counter value reaches 0.



Figure 6.9-5 WWDT Reload Counter When WWDT\_CNT &lt; 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 larger than 2. Otherwise, writing WWDT\_RLDCNT register to reload WWDT counter value to 0x3F is unavailable, WWDTIF (WWDT\_STATUS[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 0x3F and 0x0, the interrupt doesn't occur. The reset occurs when WWDT counts to 0x0, so the interrupt doesn't occur when CMPDATA is 0x0.

| PSCSEL | Prescale Value | Valid CMPDAT Value |
|--------|----------------|--------------------|
| 0000   | 1              | 0x3 ~ 0x3E         |

|        |        |            |
|--------|--------|------------|
| 0001   | 2      | 0x2 ~ 0x3E |
| Others | Others | 0x1 ~ 0x3E |

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 |
|------------------------------|--------------|-----|------------------------------|-------------|
| <b>WWDT Base Address:</b>    |              |     |                              |             |
| <b>WWDT_BA = 0x4004_0100</b> |              |     |                              |             |
| <b>WWDT_RLDCNT</b>           | WWDT_BA+0x00 | W   | WWDT Reload Counter Register | 0x0000_0000 |
| <b>WWDT_CTL</b>              | WWDT_BA+0x04 | R/W | WWDT Control Register        | 0x003F_0800 |
| <b>WWDT_STATUS</b>           | WWDT_BA+0x08 | R/W | WWDT Status Register         | 0x0000_0000 |
| <b>WWDT_CNT</b>              | WWDT_BA+0x0C | R   | WWDT Counter Value Register  | 0x0000_003F |

### 6.9.7 Register Description

#### WWDT Reload Counter Register (WWDT\_RLDCNT)

| Register    | Offset       | R/W | Description                  | Reset Value |
|-------------|--------------|-----|------------------------------|-------------|
| WWDT_RLDCNT | WWDT_BA+0x00 | W   | WWDT Reload Counter Register | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | RLDCNT      | <p><b>WWDT Reload Counter Register</b></p> <p>Writing 0x00005AA5 to this register will reload the WWDT counter value to 0x3F.</p> <p><b>Note:</b> User can only write WWDT_RLDCNT register to reload WWDT counter value when current WWDT counter value between 0 and CMPDAT (WWDT_CTL[21:16]). If user writes WWDT_RLDCNT when current WWDT counter value is larger than CMPDAT, WWDT reset signal will be generated immediately.</p> |

WWDT Control Register (WWDT\_CTL)

| Register | Offset       | R/W | Description           |  |  |  |  | Reset Value |
|----------|--------------|-----|-----------------------|--|--|--|--|-------------|
| WWDT_CTL | WWDT_BA+0x04 | R/W | WWDT Control Register |  |  |  |  | 0x003F_0800 |

**Note:** This register can be written only one time after chip is powered on or reset.

|          |          |        |    |        |    |    |       |        |
|----------|----------|--------|----|--------|----|----|-------|--------|
| 31       | 30       | 29     | 28 | 27     | 26 | 25 | 24    |        |
| ICEDEBUG | Reserved |        |    |        |    |    |       |        |
| 23       | 22       | 21     | 20 | 19     | 18 | 17 | 16    |        |
| 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    | <b>ICE Debug Mode Acknowledge Disable Bit</b><br>0 = ICE debug mode acknowledgement effects WWDT counting.<br>WWDT down counter will be held while CPU is held by ICE.<br>1 = ICE debug mode acknowledgement Disabled.<br><b>Note:</b> WWDT down counter will keep going no matter CPU is held by ICE or not.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [30:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [21:16] | CMPDAT      | <b>WWDT Window Compare</b><br>Set this register to adjust the valid reload window.<br><b>Note:</b> 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 current WWDT counter value larger than CMPDAT, WWDT reset signal will generate immediately.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [11:8]  | PSCSEL      | <b>WWDT Counter Prescale Period Selection</b><br>0000 = Pre-scale is 1; Max time-out period is 1 * 64 * WWDT_CLK.<br>0001 = Pre-scale is 2; Max time-out period is 2 * 64 * WWDT_CLK.<br>0010 = Pre-scale is 4; Max time-out period is 4 * 64 * WWDT_CLK.<br>0011 = Pre-scale is 8; Max time-out period is 8 * 64 * WWDT_CLK.<br>0100 = Pre-scale is 16; Max time-out period is 16 * 64 * WWDT_CLK.<br>0101 = Pre-scale is 32; Max time-out period is 32 * 64 * WWDT_CLK.<br>0110 = Pre-scale is 64; Max time-out period is 64 * 64 * WWDT_CLK.<br>0111 = Pre-scale is 128; Max time-out period is 128 * 64 * WWDT_CLK.<br>1000 = Pre-scale is 192; Max time-out period is 192 * 64 * WWDT_CLK.<br>1001 = Pre-scale is 256; Max time-out period is 256 * 64 * WWDT_CLK.<br>1010 = Pre-scale is 384; Max time-out period is 384 * 64 * WWDT_CLK.<br>1011 = Pre-scale is 512; Max time-out period is 512 * 64 * WWDT_CLK.<br>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.<br>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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                              |
| [1]   | <b>INTEN</b>    | <b>WWDT Interrupt Enable Bit</b><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]   | <b>WWDTEN</b>   | <b>WWDT Enable Bit</b><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 |  |  |  |  | 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 |    |    |    |    |    | WWDTRF | WWDTIF |

| Bits   | Description |                                                                                                                                                                                                                                                                                 |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                       |
| [1]    | WWDTRF      | <b>WWDT Timer-out Reset Flag</b><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><b>Note:</b> This bit is cleared by writing 1 to it.                          |
| [0]    | WWDTIF      | <b>WWDT Compare Match Interrupt Flag</b><br>This bit indicates the interrupt flag status of WWDT while WWDT counter value matches CMPDAT (WWDT_CTL[21:16]).<br>0 = No effect.<br>1 = WWDT counter value matches CMPDAT.<br><b>Note:</b> 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 |  |  |  | 0x0000_003F |

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

| Bits   | Description |                                                                                                            |
|--------|-------------|------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                  |
| [5:0]  | CNTDAT      | <b>WWDT Counter Value</b><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 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 up 3 pairs dynamic loop tamper pin or 6 individual tamper pin.
- Supports 80 bytes spare registers and tamper pins detection to clear the content of these spare registers.

### 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 (APBCLK0[1]) and RTC Time Counter source is selected by CLK\_CLKSEL3[8] LXT or LIRC.
- Pin Configuration

| Group   | Pin Name | GPIO | MFP   |
|---------|----------|------|-------|
| X32     | X32_OUT  | PF.4 | MFP10 |
|         | X32_IN   | PF.5 | MFP10 |
| TAMPER0 | TAMPER0  | PF.6 | MFP10 |
| TAMPER1 | TAMPER1  | PF.7 | MFP10 |
| TAMPER2 | TAMPER2  | PF.8 | MFP10 |

|         |         |       |       |
|---------|---------|-------|-------|
| TAMPER3 | TAMPER3 | PF.9  | MFP10 |
| TAMPER4 | TAMPER4 | PF.10 | MFP10 |
| TAMPER5 | TAMPER5 | PF.11 | MFP10 |

### 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 leave reset state. Once the INIT(RTC\_INIT[31:0]) register is written as 0xa5eb1357, the RTC will be in normal active state permanently. User can read INIT[0](RTC\_INIT[0]) to check the RTC is at normal active state or reset state.

#### 6.10.5.2 RTC Read/Write Enable

If RWENF (RTC\_RWEN[16]) bit is read as 1, it means the RTC registers are read/write accessible. When executing write RTC register command exceed 6 times within 1120 PCLK cycles, the RTCBUSY (RTC\_RWEN[24]) flag will be set 1 and RWENF (RTC\_RWEN[16]) will be clear to 0. The RTC control registers access attribute when RWENF is 1 and 0 are shown in Table 6.10-1.

| Register     | INIR = 0      | RWENF = 1 | RWENF = 0 Or RTCBUSY=1 |
|--------------|---------------|-----------|------------------------|
| RTC_INIT     | available     | R/W       | R/W                    |
| RTC_RWEN     | available     | R/W       | R/W                    |
| RTC_FREQADJ  | available     | R/W       | R                      |
| RTC_TIME     | Not available | R/W       | R                      |
| RTC_CAL      | Not available | R/W       | R                      |
| RTC_CLKFMT   | Not available | R/W       | R                      |
| RTC_WEEKDAY  | Not available | R/W       | R                      |
| RTC_TALM     | Not available | R/W       | R                      |
| RTC_CALM     | Not available | R/W       | R                      |
| RTC_LEAPYEAR | Not available | R         | R                      |
| RTC_INTEN    | available     | R/W       | R/W                    |
| RTC_INSTS    | available     | R/W       | R/W                    |
| RTC_TICK     | Not available | R/W       | R                      |
| RTC_TAMSK    | Not available | R/W       | R                      |
| RTC_CAMSK    | Not available | R/W       | R                      |
| RTC_SPRCTL   | available     | R/W       | Not available          |
| RTC_SPRx     | available     | R/W       | Not available          |
| RTC_LXTCTL   | available     | R/W       | R/W                    |
| RTC_DSTCTL   | Not available | R/W       | R                      |
| RTC_TAMPCTL  | Not available | R/W       | R                      |
| RTC_TAMPSEED | Not available | R/W       | R                      |
|              |               |           |                        |
|              |               |           |                        |
|              |               |           |                        |
|              |               |           |                        |
|              |               |           |                        |

|  |  |  |  |
|--|--|--|--|
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |

Table 6.10-1 RTC Read/Write Enable

#### 6.10.5.3 Frequency Compensation

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 32k 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 (> 32768 Hz)

$$\text{FREQADJ} = (32768 * 0x200000) / 32773.65 = 0x1FFE96$$

##### Example 2:

Frequency counter measurement : 32763.25 Hz (< 32768 Hz)

$$\text{FREQADJ} = (32768 * 0x200000) / 32763.25 = 0x200130$$

**Note:** The value of RTC\_FREQADJ register will be the default value (0x0020\_0000) 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.4 Time and Calendar Counter

RTC\_TIME and RTC\_CAL are used to load the real time and calendar. RTC\_TALM and RTC\_CALM are used for setup alarm time and calendar.

#### 6.10.5.5 12/24 hour Time Scale Selection

The 12/24 hour time scale selection depends on 24HEN (RTC\_CLKFMT[0]). When RTC runs as 12-hour time scale mode, RTC\_TIME[21] (the high bit of TENHR[1:0]) means AM/PM indication, if RTC\_TIME[21] is 1, it indicates PM time message and RTC\_TIME[21] is 0 indicates AM time message.) Table 6.10-2 shows RTC\_TIME mapping table of 12/24 hour time scale selection.

| Note: The Hour Value Write Into RTC_TIME[21:16], Messages Are Expressed In BCD Format. |             |                                                                     |             |
|----------------------------------------------------------------------------------------|-------------|---------------------------------------------------------------------|-------------|
| 24-Hour Time Scale<br>(24HEN = 1)                                                      |             | 12-Hour Time Scale (PM Time + 0x20)<br>(24HEN = 0) (PM Time + 0x20) |             |
| 0x00 (AM12)                                                                            | 0x12 (PM12) | 0x12 (AM12)                                                         | 0x32 (PM12) |
| 0x01 (AM01)                                                                            | 0x13 (PM01) | 0x01 (AM01)                                                         | 0x21 (PM01) |
| 0x02 (AM02)                                                                            | 0x14 (PM02) | 0x02 (AM02)                                                         | 0x22 (PM02) |
| 0x03 (AM03)                                                                            | 0x15 (PM03) | 0x03 (AM03)                                                         | 0x23 (PM03) |
| 0x04 (AM04)                                                                            | 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) | 0x30 (PM10) |
| 0x11 (AM11) | 0x23 (PM11) | 0x11 (AM11) | 0x31 (PM11) |

Table 6.10-212/24 Hour Time Scale Selection

#### 6.10.5.6 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.7 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.8 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\_CAL registers in each alarm interrupt service routine.

#### 6.10.5.9 Daylight Saving Time

The RTC controller also provides RTC\_DSTCTL register to store the control settings of daylight saving time application. User can read DSBAK(RTC\_DSTCTL[2]) value to check current RTC date/time counter runs in daylight saving time mode or normal mode.

#### 6.10.5.10 1 Hz clock output

The RTC controller provides 1Hz clock output to CLKO function pin. User can set CLK1HZEN (CLK\_CLKOCTL[6]) to 1 and enable RTC, 1Hz clock will output to CLKO function pin.

#### 6.10.5.11 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 20xy, rather than 19xy or 21xy.

##### 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:

##### 5. HOUR:

RTC\_TIME[21:16]: 0x32 (0x12+0x20) combined by TENHR (RTC\_TIME[21:20]) is 0x3, HR (RTC\_TIME[19:16]) is 0x2.

##### 6. MIN:

RTC\_TIME[14:8]: 0x59 combined by TENMIN (RTC\_TIME[14:12]) is 0x5, MIN (RTC\_TIME[11:8]) is 0x9.

## 7. SEC:

RTC\_TIME[6:0]: 0x30 combined by TENSEC (RTC\_TIME[6:4]) is 0x3, SEC (RTC\_TIME[3:0]) is 0x0.

8. Table 6.10-3 shows registers value after core power are first powered on.

| Register     | Reset State                       |
|--------------|-----------------------------------|
| RTC_INIT     | 0                                 |
| RTC_RWEN     | 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)         |
| 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-3 Registers Value after Powered On

9. List registers locate in Core Power Domain as Table 6.10-4.

| Register   | Power Domain      |
|------------|-------------------|
| RTC_RWEN   | Core Power Domain |
| RTC_INTEN  | Core Power Domain |
| RTC_INTSTS | Core Power Domain |
| Others     | Core Power Domain |

Table 6.10-4 Registers Power Domain

#### 6.10.5.12 Spare Registers and Tamper Detector

The RTC module is equipped with 80 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\_SPR0 ~ RTC\_SPR19).

When the transition level condition defined in RTC\_TAMPCTL is mismatch, tamper detected interrupt flag TAMPxIF (RTC\_INTSTS[13:8]) will be generated. Meanwhile, the 80 bytes spare registers (RTC\_SPR0 ~ RTC\_SPR19) 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 only can be cleared automatically or update again when all TAMPxIF are cleared to 0. And if TAMPxIF is set to 1, the interrupt is generated to NVIC if the tamper detect interrupt is activated.

RTC support 3 pair dynamic loop tamper pin or 6 individual tamper pin. The DYNRATE (RTC\_TAMPCTL[7:5]) determine a reference pattern bit duration and it is shown in Figure 6.10-2. In

Table 6.10-5, setting DYNSRC (RTC\_TAMPCTL[3:2]) can select detect signal is new value which generated by hardware random value generator, previous random value or user defined SEED value (RTC\_TAMPSEED[31:0]) for dynamic loop tamper pin. Set DYN1ISS (RTC\_TAMPCTL[0]) 1 can be select Pair1 detection source is from tamper 0, and DYN12SS (RTC\_TAMPCTL[1]) 1 can be select Pair2 detection source is also from tamper 0. The TAMPxLV (RTC\_TAMPCTL[4x+9], x=0, 1, ..., 5) depend on level attribute of TAMPERx pin for individual tamper detection. The tamper control effect is shown in Table 6.10-6 and Table 6.10-7.



Figure 6.10-2 Dynamic Rate Definition

| DYNPRxEN | DYNSRC[1:0] | The Detect Signal Description                                                 |
|----------|-------------|-------------------------------------------------------------------------------|
| 0        | x           | The TAMPERn is static tamper detection (n=0 ~ 5)                              |
| 1        | 00          | Generating new random value as reference pattern when the value runs out      |
| 1        | 01          | Repeated previous random value as reference pattern when the value runs out   |
| 1        | 10          | Generating new random value as reference pattern when the value runs out      |
| 1        | 11          | Repeated user defined SEED value as reference pattern when the value runs out |

Table 6.10-5 Dynamic Pattern Source Selection

| Tamper Configuration |           |           | Tamper Control Bit Effect |         |            |            |             |            |  |
|----------------------|-----------|-----------|---------------------------|---------|------------|------------|-------------|------------|--|
| DYNPR0EN             | TAMPER0EN | TAMPER1EN | TAMP0LV                   | TAMP1LV | TAMP0DBE N | TAMP1DBE N | TAMPER 0    | TAMPER 1   |  |
| 0                    | 0         | 0         | -                         | -       | -          | -          | -           | -          |  |
| 0                    | 0         | 1         | -                         | V       | -          | V          | -           | Static     |  |
| 0                    | 1         | 0         | V                         | -       | V          | -          | Static      | X          |  |
| 0                    | 1         | 1         | V                         | V       | V          | V          | Static      | Static     |  |
| 1                    | x         | 0         | -                         | -       | -          | -          | Dynamic Out | -          |  |
| 1                    | x         | 1         | -                         | -       | -          | -          | Dynamic Out | Dynamic In |  |

Table 6.10-6 Tamper Control Bit Effect for Pair 0

| Tamper Configuration |         |            |            | Tamper Control Bit Effect |         |            |             |          |          |
|----------------------|---------|------------|------------|---------------------------|---------|------------|-------------|----------|----------|
| DYNPRxE N            | DYNxISS | TAMPERn EN | TAMPEm REN | TAMPnLV                   | TAMPmLV | TAMPnDBE N | TAMPmDB E N | TAMPER n | TAMPER m |
| 0                    | x       | 0          | 0          | -                         | -       | -          | -           | -        | -        |

|            |   |                        |   |   |   |   |   |             |                             |
|------------|---|------------------------|---|---|---|---|---|-------------|-----------------------------|
| 0          | x | 0                      | 1 | - | V | - | V | -           | Static                      |
| 0          | x | 1                      | 0 | V | - | V | - | Static      | -                           |
| 0          | x | 1                      | 1 | V | V | V | V | Static      | Static                      |
| 1          | 0 | x                      | 0 | - | - | - | - | Dynamic Out | -                           |
| 1          | 0 | x                      | 1 | - | - | - | - | Dynamic Out | Dynamic In                  |
| 1          | 1 | 0                      | 1 | - | - | - | - | -           | Dynamic Input form TAMPER 0 |
| 1          | 1 | 1                      | 1 | V | V | - | - | Static      | Dynamic Input form TAMPER 0 |
| x= 1 and 2 |   | n= 2 and 4, m= 3 and 5 |   |   |   |   |   |             |                             |

Table 6.10-7 Tamper Control Bit Effect for Pair 1 and 2

**Static Tamper Programming Sequence Example**

Clean the TAMPxIF (RTC\_INTSTS[x+8], x=0, 1, ..., 5)

1. Set TAMPxLV (RTC\_TAMPCTL[4x+9], x=0, 1, ..., 5) and TAMPxDBEN (RTC\_TAMPCTL[4x+10], x=0, 1, ..., 5).
2. Enable TAMPxEN (RTC\_TAMPCTL[4x+8], x=0, 1, ..., 5).

**Dynamic Tamper Programming Sequence Example**

1. Clean the TAMPxIF (RTC\_INTSTS[x+8], x=0, 1, ..., 5)
2. Fill the SEED (RTC\_TAMPSEED[31:0]).
3. Setting DYNsrc (RTC\_TAMPCTL[3:2]), DYNxISS (RTC\_TAMPCTL[x], x=0, 1) and DYNRATE (RTC\_TAMPCTL[7:5]).
4. Enable DYNPRxEN (RTC\_TAMPCTL[8x+16], x=0, 1, 2).
5. Enable TAMPxEN (RTC\_TAMPCTL[4x+8], x=0, 1, ..., 5).
6. Set SEEDRLD (RTC\_TAMPCTL[4]).

### 6.10.5.13 Backup Domain GPIO Function

When PF.4/X32O and PF.5/X32I pins are not used as low speed 32K oscillator function, they can be used as GPIO pin function. The CTLSEL0 (RTC\_GPIOCTL0[3]) is used to select the PF.4/X32O pin is controlled by RTC or GPIO module and the PF.5/X32I pin is controlled by CTLSEL1 in RTC\_GPIOCTL0[11]. Figure 6.10-3 shows backup I/O control diagram.



Figure 6.10-3 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 |
|-----------------------------|-------------|-----|---------------------------------------|-------------|
| <b>RTC Base Address:</b>    |             |     |                                       |             |
| <b>RTC_BA = 0x4004_1000</b> |             |     |                                       |             |
| <b>RTC_INIT</b>             | RTC_BA+0x00 | R/W | RTC Initiation Register               | 0x0000_0000 |
| <b>RTC_RWEN</b>             | RTC_BA+0x04 | R/W | RTC Access Enable Register            | 0x0000_0000 |
| <b>RTC_FREQADJ</b>          | RTC_BA+0x08 | R/W | RTC Frequency Compensation Register   | 0x0020_0000 |
| <b>RTC_TIME</b>             | RTC_BA+0x0C | R/W | RTC Time Loading Register             | 0x0000_0000 |
| <b>RTC_CAL</b>              | RTC_BA+0x10 | R/W | RTC Calendar Loading Register         | 0x0015_0808 |
| <b>RTC_CLKFMT</b>           | RTC_BA+0x14 | R/W | RTC Time Scale Selection Register     | 0x0000_0001 |
| <b>RTC_WEEKDAY</b>          | RTC_BA+0x18 | R/W | RTC Day of the Week Register          | 0x0000_0006 |
| <b>RTC_TALM</b>             | RTC_BA+0x1C | R/W | RTC Time Alarm Register               | 0x0000_0000 |
| <b>RTC_CALM</b>             | RTC_BA+0x20 | R/W | RTC Calendar Alarm Register           | 0x0000_0000 |
| <b>RTC_LEAPYEAR</b>         | RTC_BA+0x24 | R   | RTC Leap Year Indicator Register      | 0x0000_0000 |
| <b>RTC_INTEN</b>            | RTC_BA+0x28 | R/W | RTC Interrupt Enable Register         | 0x0000_0000 |
| <b>RTC_INTSTS</b>           | RTC_BA+0x2C | R/W | RTC Interrupt Status Register         | 0x0000_0000 |
| <b>RTC_TICK</b>             | RTC_BA+0x30 | R/W | RTC Time Tick Register                | 0x0000_0000 |
| <b>RTC_TAMSK</b>            | RTC_BA+0x34 | R/W | RTC Time Alarm Mask Register          | 0x0000_0000 |
| <b>RTC_CAMSK</b>            | RTC_BA+0x38 | R/W | RTC Calendar Alarm Mask Register      | 0x0000_0000 |
| <b>RTC_SPRCTL</b>           | RTC_BA+0x3C | R/W | RTC Spare Functional Control Register | 0x0000_0000 |
| <b>RTC_SPR0</b>             | RTC_BA+0x40 | R/W | RTC Spare Register 0                  | 0x0000_0000 |
| <b>RTC_SPR1</b>             | RTC_BA+0x44 | R/W | RTC Spare Register 1                  | 0x0000_0000 |
| <b>RTC_SPR2</b>             | RTC_BA+0x48 | R/W | RTC Spare Register 2                  | 0x0000_0000 |
| <b>RTC_SPR3</b>             | RTC_BA+0x4C | R/W | RTC Spare Register 3                  | 0x0000_0000 |
| <b>RTC_SPR4</b>             | RTC_BA+0x50 | R/W | RTC Spare Register 4                  | 0x0000_0000 |
| <b>RTC_SPR5</b>             | RTC_BA+0x54 | R/W | RTC Spare Register 5                  | 0x0000_0000 |
| <b>RTC_SPR6</b>             | RTC_BA+0x58 | R/W | RTC Spare Register 6                  | 0x0000_0000 |
| <b>RTC_SPR7</b>             | RTC_BA+0x5C | R/W | RTC Spare Register 7                  | 0x0000_0000 |
| <b>RTC_SPR8</b>             | RTC_BA+0x60 | R/W | RTC Spare Register 8                  | 0x0000_0000 |
| <b>RTC_SPR9</b>             | RTC_BA+0x64 | R/W | RTC Spare Register 9                  | 0x0000_0000 |

|               |              |     |                                            |             |
|---------------|--------------|-----|--------------------------------------------|-------------|
| RTC_SPR10     | RTC_BA+0x68  | R/W | RTC Spare Register 10                      | 0x0000_0000 |
| RTC_SPR11     | RTC_BA+0x6C  | R/W | RTC Spare Register 11                      | 0x0000_0000 |
| RTC_SPR12     | RTC_BA+0x70  | R/W | RTC Spare Register 12                      | 0x0000_0000 |
| RTC_SPR13     | RTC_BA+0x74  | R/W | RTC Spare Register 13                      | 0x0000_0000 |
| RTC_SPR14     | RTC_BA+0x78  | R/W | RTC Spare Register 14                      | 0x0000_0000 |
| RTC_SPR15     | RTC_BA+0x7C  | R/W | RTC Spare Register 15                      | 0x0000_0000 |
| RTC_SPR16     | RTC_BA+0x80  | R/W | RTC Spare Register 16                      | 0x0000_0000 |
| RTC_SPR17     | RTC_BA+0x84  | R/W | RTC Spare Register 17                      | 0x0000_0000 |
| RTC_SPR18     | RTC_BA+0x88  | R/W | RTC Spare Register 18                      | 0x0000_0000 |
| RTC_SPR19     | RTC_BA+0x8C  | R/W | RTC Spare Register 19                      | 0x0000_0000 |
| RTC_LXTCTL    | RTC_BA+0x100 | R/W | RTC 32.768 kHz Oscillator Control Register | 0x0000_000E |
| RTC_GPIOCTL_0 | RTC_BA+0x104 | R/W | RTC GPIO Control 0 Register                | 0x0000_0000 |
| RTC_GPIOCTL_1 | RTC_BA+0x108 | R/W | RTC GPIO Control 1 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_TAMPSEED  | RTC_BA+0x128 | R/W | RTC Tamper Dynamic Seed 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 |  |  |  |  | 0x0000_0000 |



| Bits   | Description           |                                                                                                                                                                                                                                                                                                                                     |
|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | <b>INIT[31:1]</b>     | <b>RTC Initiation (Write Only)</b><br>When RTC block is powered on, RTC is at reset state. User has to write a number (0xa5eb1357) to INIT to make RTC leave reset state. Once the INIT is written as 0xa5eb1357, the RTC will be in un-reset state permanently.<br>The INIT is a write-only field and read value will be always 0. |
| [0]    | <b>INIT[0]/ACTIVE</b> | <b>RTC Active Status (Read Only)</b><br>0 = RTC is at reset state.<br>1 = RTC is at normal active state.                                                                                                                                                                                                                            |

RTC Access Enable Register (RTC\_RWEN)

| Register | Offset      | R/W | Description                |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------|--|--|--|-------------|
| RTC_RWEN | RTC_BA+0x04 | R/W | RTC Access Enable Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                     |
| [24]    | RTCBUSY     | <p><b>RTC Write Busy Flag</b><br/>           This bit indicates RTC registers are writable or not.<br/>           0 = RTC registers are writable.<br/>           1 = RTC registers can't be written. RTC is under Busy Status.<br/> <b>Note:</b> RTCBUSY flag will be set when execute write RTC register command exceed 6 times within 1120 PCLK cycles.</p> |
| [23:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                     |
| [16]    | RWENF       | <p><b>RTC Register Access Enable Flag (Read Only)</b><br/>           0 = RTC register read/write Disabled.<br/>           1 = RTC register read/write Enabled.<br/> <b>Note:</b> RWENF will be masked to 0 during RTCBUSY is 1, and first turn on RTCCKEN (CLK_APBCLK[1]) also.</p>                                                                           |
| [15:0]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                     |

**RTC Frequency Compensation Register (RTC\_FREQADJ)**

| Register    | Offset      | R/W | Description                         |  |  |  | Reset Value |
|-------------|-------------|-----|-------------------------------------|--|--|--|-------------|
| RTC_FREQADJ | RTC_BA+0x08 | R/W | RTC Frequency Compensation Register |  |  |  | 0x0020_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                               |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                     |
| [21:0]  | FREQADJ     | <p><b>Frequency Compensation Register</b><br/> User must to get actual LXT frequency for RTC application.<br/> <math>FCR = 0x200000 * (32768 / LXT\ frequency)</math>.</p> <p><b>Note:</b> This formula is suitable only when RTC clock source is from LXT, RTCSEL (CLK_CLKSEL3[8]) is 0.</p> |

**RTC Time Loading Register (RTC\_TIME)**

| Register | Offset      | R/W | Description               |  |  |  |  | Reset Value |
|----------|-------------|-----|---------------------------|--|--|--|--|-------------|
| RTC_TIME | RTC_BA+0x0C | R/W | RTC Time Loading Register |  |  |  |  | 0x0000_0000 |

|          |    |        |    |    |    |     |    |
|----------|----|--------|----|----|----|-----|----|
| 31       | 30 | 29     | 28 | 27 | 26 | 25  | 24 |
| Reserved |    |        |    |    |    |     |    |
| 23       | 22 | 21     | 20 | 19 | 18 | 17  | 16 |
| 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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                    |
| [21:20] | <b>TENHR</b>    | 10-Hour Time Digit (0~2)<br>When RTC runs as 12-hour 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.) |
| [19:16] | <b>HR</b>       | 1-Hour Time Digit (0~9)                                                                                                                                                                      |
| [15]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                    |
| [14:12] | <b>TENMIN</b>   | 10-Min Time Digit (0~5)                                                                                                                                                                      |
| [11:8]  | <b>MIN</b>      | 1-Min Time Digit (0~9)                                                                                                                                                                       |
| [7]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                    |
| [6:4]   | <b>TENSEC</b>   | 10-Sec Time Digit (0~5)                                                                                                                                                                      |
| [3:0]   | <b>SEC</b>      | 1-Sec Time Digit (0~9)                                                                                                                                                                       |

**Note:**

1. RTC\_TIME is a BCD digit counter and RTC will not check loaded data.
2. The reasonable value range is listed in the parenthesis.
3. FREQADJ's counter will be reset for start to Compensation 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+0x10 | R/W | RTC Calendar Loading Register |  |  |  | 0x0015_0808 |

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

| Bits    | Description |                               |
|---------|-------------|-------------------------------|
| [31:24] | Reserved    | Reserved.                     |
| [23:20] | TENYEAR     | 10-Year Calendar Digit (0~9)  |
| [19:16] | YEAR        | 1-Year Calendar Digit (0~9)   |
| [15:13] | Reserved    | Reserved.                     |
| [12]    | TENMON      | 10-Month Calendar Digit (0~1) |
| [11:8]  | MON         | 1-Month Calendar Digit (0~9)  |
| [7:6]   | Reserved    | Reserved.                     |
| [5:4]   | TENDAY      | 10-Day Calendar Digit (0~3)   |
| [3:0]   | DAY         | 1-Day Calendar Digit (0~9)    |

**Note:**

1. RTC\_CAL is a BCD digit counter and RTC will not check loaded data.
2. The reasonable value range is listed in the parenthesis.

RTC Time Scale Selection Register (RTC\_CLKFMT)

| Register   | Offset      | R/W | Description                       |  |  |  |  | Reset Value |
|------------|-------------|-----|-----------------------------------|--|--|--|--|-------------|
| RTC_CLKFMT | RTC_BA+0x14 | R/W | RTC Time Scale Selection Register |  |  |  |  | 0x0000_0001 |

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

| Bits   | Description |                                                                                                                                                                                                                                                         |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                               |
| [0]    | 24HEN       | <p><b>24-hour / 12-hour Time Scale Selection</b></p> <p>Indicates that RTC_TIME and RTC_TALM are in 24-hour time scale or 12-hour time scale</p> <p>0 = 12-hour time scale with AM and PM indication selected.<br/>1 = 24-hour time scale selected.</p> |

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 | 0x0000_0006 |

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

| Bits   | Description |                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                         |
| [2:0]  | WEEKDAY     | <b>Day of the Week Register</b><br>000 = Sunday.<br>001 = Monday.<br>010 = Tuesday.<br>011 = Wednesday.<br>100 = Thursday.<br>101 = Friday.<br>110 = Saturday.<br>111 = Reserved. |

**RTC Time Alarm Register (RTC\_TALM)**

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| RTC_TALM | RTC_BA+0x1C | R/W | RTC Time Alarm Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                     |
| [21:20] | TENHR       | 10-Hour Time Digit of Alarm Setting (0~2)<br>When RTC runs as 12-hour time scale mode, RTC_TIME[21] (the high bit of TENHR[1:0]) means AM/PM indication (If RTC_TIME[21] is 1, it indicates PM time message.) |
| [19:16] | HR          | 1-Hour Time Digit of Alarm Setting (0~9)                                                                                                                                                                      |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                     |
| [14:12] | TENMIN      | 10-Min Time Digit of Alarm Setting (0~5)                                                                                                                                                                      |
| [11:8]  | MIN         | 1-Min Time Digit of Alarm Setting (0~9)                                                                                                                                                                       |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                     |
| [6:4]   | TENSEC      | 10-Sec Time Digit of Alarm Setting (0~5)                                                                                                                                                                      |
| [3:0]   | SEC         | 1-Sec Time Digit of Alarm Setting (0~9)                                                                                                                                                                       |

**Note:**

1. RTC\_TALM is a BCD digit counter.
2. The reasonable value range is listed in the parenthesis.
3. This register can be read back after the RTC register access enable bit RWENF (RTC\_RWEN[16]) is active.

RTC Calendar Alarm Register (RTC\_CALM)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| RTC_CALM | RTC_BA+0x20 | R/W | RTC Calendar Alarm Register | 0x0000_0000 |

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

| Bits    | Description |                                                |
|---------|-------------|------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                      |
| [23:20] | TENYEAR     | 10-Year Calendar Digit of Alarm Setting (0~9)  |
| [19:16] | YEAR        | 1-Year Calendar Digit of Alarm Setting (0~9)   |
| [15:13] | Reserved    | Reserved.                                      |
| [12]    | TENMON      | 10-Month Calendar Digit of Alarm Setting (0~1) |
| [11:8]  | MON         | 1-Month Calendar Digit of Alarm Setting (0~9)  |
| [7:6]   | Reserved    | Reserved.                                      |
| [5:4]   | TENDAY      | 10-Day Calendar Digit of Alarm Setting (0~3)   |
| [3:0]   | DAY         | 1-Day Calendar Digit of Alarm Setting (0~9)    |

**Note:**

1. RTC\_CALM is a BCD digit counter.
2. The reasonable value range is listed in the parenthesis.
3. This register can be read back after the RTC register access enable bit RWENF (RTC\_RWEN[16]) is active.

**RTC Leap Year Indication Register (RTC\_LEAPYEAR)**

| Register     | Offset      | R/W | Description                      | Reset Value |
|--------------|-------------|-----|----------------------------------|-------------|
| RTC_LEAPYEAR | RTC_BA+0x24 | R   | RTC Leap Year Indicator Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                             |
|--------|-------------|-------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                   |
| [0]    | LEAPYEAR    | <b>Leap Year Indication (Read Only)</b><br>0 = This year is not a leap year.<br>1 = This year is leap year. |

RTC Interrupt Enable Register (RTC\_INTEN)

| Register  | Offset      | R/W | Description                   |  |  |  | Reset Value |
|-----------|-------------|-----|-------------------------------|--|--|--|-------------|
| RTC_INTEN | RTC_BA+0x28 | R/W | RTC Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                  |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                        |
| [13]    | <b>TAMP5IEN</b> | <b>Tamper 5 or Pair 2 Interrupt Enable Bit</b><br>Set TAMP5IEN to 1 can also enable chip wake-up function when tamper 5 interrupt event is generated.<br>0 = Tamper 5 or Pair 2 interrupt Disabled.<br>1 = Tamper 5 or Pair 2 interrupt Enabled. |
| [12]    | <b>TAMP4IEN</b> | <b>Tamper 4 Interrupt Enable Bit</b><br>Set TAMP4IEN to 1 can also enable chip wake-up function when tamper 4 interrupt event is generated.<br>0 = Tamper 4 interrupt Disabled.<br>1 = Tamper 4 interrupt Enabled.                               |
| [11]    | <b>TAMP3IEN</b> | <b>Tamper 3 or Pair 1 Interrupt Enable Bit</b><br>Set TAMP3IEN to 1 can also enable chip wake-up function when tamper 3 interrupt event is generated.<br>0 = Tamper 3 or Pair 1 interrupt Disabled.<br>1 = Tamper 3 or Pair 1 interrupt Enabled. |
| [10]    | <b>TAMP2IEN</b> | <b>Tamper 2 Interrupt Enable Bit</b><br>Set TAMP2IEN to 1 can also enable chip wake-up function when tamper 2 interrupt event is generated.<br>0 = Tamper 2 interrupt Disabled.<br>1 = Tamper 2 interrupt Enabled.                               |
| [9]     | <b>TAMP1IEN</b> | <b>Tamper 1 or Pair 0 Interrupt Enable Bit</b><br>Set TAMP1IEN to 1 can also enable chip wake-up function when tamper 1 interrupt event is generated.<br>0 = Tamper 1 or Pair 0 interrupt Disabled.<br>1 = Tamper 1 or Pair 0 interrupt Enabled. |
| [8]     | <b>TAMPOIEN</b> | <b>Tamper 0 Interrupt Enable Bit</b><br>Set 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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                    |
| [1]   | <b>TICKIEN</b>  | <b>Time Tick Interrupt Enable Bit</b><br>Set 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]   | <b>ALMIEN</b>   | <b>Alarm Interrupt Enable Bit</b><br>Set 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+0x2C | R/W | RTC Interrupt Status Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [13]    | <b>TAMP5IF</b>  | <p><b>Tamper 5 or Pair 2 Interrupt Flag</b><br/> This bit is set when TAMP5_PIN detected level non-equal TAMP5LV (RTC_TAMPCTL[29]) or TAMP4_PIN and TAMP5_PIN disconnected during DYNPR2EN (RTC_TAMPCTL[31]) is activated or TAMP0_PIN and TAMP5_PIN disconnected during DYNPR2EN (RTC_TAMPCTL[31]) and DYN2ISS (RTC_TAMPCTL[1]) are activated.<br/> 0 = No Tamper 5 or Pair 2 interrupt flag is generated.<br/> 1 = Tamper 5 or Pair 2 interrupt flag is generated.<br/> <b>Note1:</b> Write 1 to clear this bit.<br/> <b>Note2:</b> Clear all TAPMxF will clear RTC_TAMPTIME and RTC_TAMPCAL automatically.</p> |
| [12]    | <b>TAMP4IF</b>  | <p><b>Tamper 4 Interrupt Flag</b><br/> This bit is set when TAMP4_PIN detected level non-equal TAMP4LV (RTC_TAMPCTL[25]).<br/> 0 = No Tamper 4 interrupt flag is generated.<br/> 1 = Tamper 4 interrupt flag is generated.<br/> <b>Note1:</b> Write 1 to clear this bit.<br/> <b>Note2:</b> Clear all TAPMxF will clear RTC_TAMPTIME and RTC_TAMPCAL automatically.</p>                                                                                                                                                                                                                                           |
| [11]    | <b>TAMP3IF</b>  | <p><b>Tamper 3 or Pair 1 Interrupt Flag</b><br/> This bit is set when TAMP3_PIN detected level non-equal TAMP3LV (RTC_TAMPCTL[21]) or TAMP2_PIN and TAMP3_PIN disconnected during DYNPR1EN (RTC_TAMPCTL[23]) is activated or TAMP0_PIN and TAMP3_PIN disconnected during DYNPR1EN (RTC_TAMPCTL[23]) and DYN1ISS (RTC_TAMPCTL[0]) are activated.<br/> 0 = No Tamper 3 or Pair 1 interrupt flag is generated.<br/> 1 = Tamper 3 or Pair 1 interrupt flag is generated.<br/> <b>Note1:</b> Write 1 to clear this bit.<br/> <b>Note2:</b> Clear all TAPMxF will clear RTC_TAMPTIME and RTC_TAMPCAL automatically.</p> |
| [10]    | <b>TAMP2IF</b>  | <p><b>Tamper 2 Interrupt Flag</b><br/> This bit is set when TAMP2_PIN detected level non-equal TAMP2LV (RTC_TAMPCTL[17]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | <p>0 = No Tamper 2 interrupt flag is generated.<br/>1 = Tamper 2 interrupt flag is generated.</p> <p><b>Note1:</b> Write 1 to clear this bit.</p> <p><b>Note2:</b> Clear all TAPMxF will clear RTC_TAMPTIME and RTC_TAMPCAL automatically.</p>                                                                                                                                                                                                                                                   |
| [9]   | <b>TAMP1IF</b>  | <p><b>Tamper 1 or Pair 0 Interrupt Flag</b><br/>This bit is set when TAMP1_PIN detected level non-equal TAMP1LV (RTC_TAMPCTL[13]) or TAMP0_PIN and TAMP1_PIN disconnected during DYNPR0EN (RTC_TAMPCTL[15]) is activated.</p> <p>0 = No Tamper 1 or Pair 0 interrupt flag is generated.<br/>1 = Tamper 1 or Pair 0 interrupt flag is generated.</p> <p><b>Note1:</b> Write 1 to clear this bit.</p> <p><b>Note2:</b> Clear all TAPMxF will clear RTC_TAMPTIME and RTC_TAMPCAL automatically.</p> |
| [8]   | <b>TAMP0IF</b>  | <p><b>Tamper 0 Interrupt Flag</b><br/>This bit is set when TAMP0_PIN detected level non-equal TAMP0LV (RTC_TAMPCTL[9]).</p> <p>0 = No Tamper 0 interrupt flag is generated.<br/>1 = Tamper 0 interrupt flag is generated.</p> <p><b>Note1:</b> Write 1 to clear this bit.</p> <p><b>Note2:</b> Clear all TAPMxF will clear RTC_TAMPTIME and RTC_TAMPCAL automatically.</p>                                                                                                                       |
| [7:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [1]   | <b>TICKIF</b>   | <p><b>RTC Time Tick Interrupt Flag</b><br/>0 = Tick condition did not occur.<br/>1 = Tick condition occurred.</p> <p><b>Note:</b> Write 1 to clear this bit.</p>                                                                                                                                                                                                                                                                                                                                 |
| [0]   | <b>ALMIF</b>    | <p><b>RTC Alarm Interrupt Flag</b><br/>0 = Alarm condition is not matched.<br/>1 = Alarm condition is matched.</p> <p><b>Note:</b> Write 1 to clear this bit.</p>                                                                                                                                                                                                                                                                                                                                |

**RTC Time Tick Register (RTC TICK)**

| Register | Offset      | R/W | Description            |  |  |  |  | Reset Value |
|----------|-------------|-----|------------------------|--|--|--|--|-------------|
| RTC_TICK | RTC_BA+0x30 | R/W | RTC Time Tick Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [2:0]  | TICK        | <p><b>Time Tick Register</b></p> <p>These bits are used to select RTC time tick period for Periodic Time Tick Interrupt request.</p> <p>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.</p> <p><b>Note:</b> This register can be read back after the RTC register access enable bit RWENF (RTC_RWEN[16]) is active.</p> |

**Note:** This register can be read back after the RTC register access enable bit RWENF (RTC\_RWEN[16]) is active.

RTC Time Alarm MASK Register (RTC\_TAMSK)

| Register  | Offset      | R/W | Description                  |  |  |  | Reset Value |
|-----------|-------------|-----|------------------------------|--|--|--|-------------|
| RTC_TAMSK | RTC_BA+0x34 | R/W | RTC Time Alarm Mask Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                |
|--------|-------------|------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                      |
| [5]    | MTENHR      | Mask 10-Hour Time Digit of Alarm Setting (0~2) |
| [4]    | MHR         | Mask 1-Hour Time Digit of Alarm Setting (0~9)  |
| [3]    | MTENMIN     | Mask 10-Min Time Digit of Alarm Setting (0~5)  |
| [2]    | MMIN        | Mask 1-Min Time Digit of Alarm Setting (0~9)   |
| [1]    | MTENSEC     | Mask 10-Sec Time Digit of Alarm Setting (0~5)  |
| [0]    | MSEC        | Mask 1-Sec Time Digit of Alarm Setting (0~9)   |

**Note:**

1. RTC\_TALM is a BCD digit counter and RTC will not check loaded data.
2. The reasonable value range is listed in the parenthesis.
3. 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+0x38 | R/W | RTC Calendar Alarm Mask Register |  |  |  |  | 0x0000_0000 |

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

| Bits | Description |                                                     |
|------|-------------|-----------------------------------------------------|
|      | Reserved    | Reserved.                                           |
| [5]  | MTENYEAR    | Mask 10-Year Calendar Digit of Alarm Setting (0~9)  |
| [4]  | MYEAR       | Mask 1-Year Calendar Digit of Alarm Setting (0~9)   |
| [3]  | MTENMON     | Mask 10-Month Calendar Digit of Alarm Setting (0~1) |
| [2]  | MMON        | Mask 1-Month Calendar Digit of Alarm Setting (0~9)  |
| [1]  | MTENDAY     | Mask 10-Day Calendar Digit of Alarm Setting (0~3)   |
| [0]  | MDAY        | Mask 1-Day Calendar Digit of Alarm Setting (0~9)    |

**Note:**

1. RTC\_CALM is a BCD digit counter and RTC will not check loaded data.
2. The reasonable value range is listed in the parenthesis.

RTC Spare Functional Control Register (RTC\_SPRCTL)

| Register   | Offset      | R/W | Description                           |  |  |  |  | Reset Value |
|------------|-------------|-----|---------------------------------------|--|--|--|--|-------------|
| RTC_SPRCTL | RTC_BA+0x3C | R/W | RTC Spare Functional 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 |    | SPRCSTS | Reserved |    | SPRRWEN | Reserved |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                      |
| [5]    | SPRCSTS     | <p><b>SPR Clear Flag</b><br/>           This bit indicates if the RTC_SPR0 ~RTC_SPR19 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/> <b>Note1:</b> Write 1 to clear this bit.<br/> <b>Note2:</b> This bit keeps 1 when RTC_INTSTS[13:8] is not equal to 0.</p> |
| [4:3]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                      |
| [2]    | SPRRWEN     | <p><b>Spare Register Enable Bit</b><br/>           0 = Spare register Disabled.<br/>           1 = Spare register Enabled.<br/> <b>Note:</b> When spare register is disabled, RTC_SPR0 ~ RTC_SPR19 cannot be accessed.</p>                                                                                                                                                                     |
| [1:0]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                      |

**RTC Spare Register (RTC SPRx)**

| Register  | Offset      | R/W | Description           | Reset Value |
|-----------|-------------|-----|-----------------------|-------------|
| RTC_SPR0  | 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_SPR5  | RTC_BA+0x54 | R/W | RTC Spare Register 5  | 0x0000_0000 |
| RTC_SPR6  | RTC_BA+0x58 | R/W | RTC Spare Register 6  | 0x0000_0000 |
| RTC_SPR7  | RTC_BA+0x5C | R/W | RTC Spare Register 7  | 0x0000_0000 |
| RTC_SPR8  | RTC_BA+0x60 | R/W | RTC Spare Register 8  | 0x0000_0000 |
| RTC_SPR9  | RTC_BA+0x64 | R/W | RTC Spare Register 9  | 0x0000_0000 |
| RTC_SPR10 | RTC_BA+0x68 | R/W | RTC Spare Register 10 | 0x0000_0000 |
| RTC_SPR11 | RTC_BA+0x6C | R/W | RTC Spare Register 11 | 0x0000_0000 |
| RTC_SPR12 | RTC_BA+0x70 | R/W | RTC Spare Register 12 | 0x0000_0000 |
| RTC_SPR13 | RTC_BA+0x74 | R/W | RTC Spare Register 13 | 0x0000_0000 |
| RTC_SPR14 | RTC_BA+0x78 | R/W | RTC Spare Register 14 | 0x0000_0000 |
| RTC_SPR15 | RTC_BA+0x7C | R/W | RTC Spare Register 15 | 0x0000_0000 |
| RTC_SPR16 | RTC_BA+0x80 | R/W | RTC Spare Register 16 | 0x0000_0000 |
| RTC_SPR17 | RTC_BA+0x84 | R/W | RTC Spare Register 17 | 0x0000_0000 |
| RTC_SPR18 | RTC_BA+0x88 | R/W | RTC Spare Register 18 | 0x0000_0000 |
| RTC_SPR19 | RTC_BA+0x8C | R/W | RTC Spare Register 19 | 0x0000_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] | <b>SPARE</b> | <b>Spare Register</b><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.<br>Before storing back-up information in to RTC_SPRx register, user should check REWNF (RTC_RWN[16]) is enabled. |

**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 |  |  |  | 0x0000_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 |    |    |    |    |      |    |          |
| 7        | 6  | 5  | 4  | 3  | 2    | 1  | 0        |
| Reserved |    |    |    |    | GAIN |    | Reserved |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                      |
| [2:1]  | GAIN        | <p><b>Oscillator Gain Option</b></p> <p>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.</p> <p>00 = L0 mode.<br/>01 = L1 mode.<br/>10 = L2 mode.<br/>11 = L3 mode.</p> |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                      |

## RTC GPIO Control Register0 (RTC\_GPIOCTL0)

| Register     | Offset       | R/W | Description                 |  |  |  | Reset Value |
|--------------|--------------|-----|-----------------------------|--|--|--|-------------|
| RTC_GPIOCTL0 | RTC_BA+0x104 | R/W | RTC GPIO Control 0 Register |  |  |  | 0x0000_0000 |

|          |    |        |    |         |       |         |    |
|----------|----|--------|----|---------|-------|---------|----|
| 31       | 30 | 29     | 28 | 27      | 26    | 25      | 24 |
| Reserved |    | PUSEL3 |    | CTLSEL3 | DOUT3 | OPMODE3 |    |
| 23       | 22 | 21     | 20 | 19      | 18    | 17      | 16 |
| Reserved |    | PUSEL2 |    | CTLSEL2 | DOUT2 | OPMODE2 |    |
| 15       | 14 | 13     | 12 | 11      | 10    | 9       | 8  |
| Reserved |    | PUSEL1 |    | CTLSEL1 | DOUT1 | OPMODE1 |    |
| 7        | 6  | 5      | 4  | 3       | 2     | 1       | 0  |
| Reserved |    | PUSEL0 |    | CTLSEL0 | DOUT0 | OPMODE0 |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [29:28] | PUSEL3      | <p><b>IO Pull-up and Pull-down Enable Bits</b><br/> Determine PF.7 I/O pull-up or pull-down.<br/> 00 = PF.7 pull-up and pull-down disable.<br/> 01 = PF.7 pull-up enable.<br/> 10 = PF.7 pull-down enable.</p> <p><b>Note:</b> 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.</p>                                                                                                                                                                                                                                                                                                              |
| [27]    | CTLSEL3     | <p><b>IO Pin State Backup Selection</b><br/> When TAMP1EN is disabled, PF.7 pin (TAMPER1 pin) can be used as GPIO function.<br/> User can program CTLSEL3 to decide PF.7 I/O function is controlled by system power domain GPIO module or V<sub>BAT</sub> power domain RTC_GPIOCTL0 control register.<br/> 0 = PF.7 pin I/O function is controlled by GPIO module.<br/> Hardware auto becomes CTLSEL3 = 1 when system power is turned off.<br/> 1 = PF.7 pin I/O function is controlled by V<sub>BAT</sub> power domain.<br/> PF.7 pin function and I/O status are controlled by OPMODE3[1:0] and DOUT3 after CTLSEL3 is set to 1.</p> <p><b>Note:</b> CTLSEL3 will automatically be set by hardware to 1 when system power is off and INIT[0](RTC_INIT[0]) is 1.</p> |
| [26]    | DOUT3       | <p><b>IO Output Data</b><br/> 0 = PF.7 output low.<br/> 1 = PF.7 output high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [25:24] | OPMODE3     | <p><b>IO Operation Mode</b><br/> 00 = PF.7 is input only mode.<br/> 01 = PF.7 is output push pull mode.<br/> 10 = PF.7 is open drain mode.<br/> 11 = PF.7 is quasi-bidirectional mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23:22] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [21:20] | <b>PUSEL2</b>   | <p><b>IO Pull-up and Pull-down Enable Bits</b><br/> Determine PF.6 I/O pull-up or pull-down.<br/> 00 = PF.6 pull-up and pull-down disable.<br/> 01 = PF.6 pull-up enable.<br/> 10 = PF.6 pull-down enable.</p> <p><b>Note1:</b><br/> 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.</p>                                                                                                                                                                                                                                                                                                         |
| [19]    | <b>CTLSEL2</b>  | <p><b>IO Pin State Backup Selection</b><br/> When TAMPOEN is disabled, PF.6 pin (TAMPER0 pin) can be used as GPIO function.<br/> User can program CTLSEL2 to decide PF.6 I/O function is controlled by system power domain GPIO module or V<sub>BAT</sub> power domain RTC_GPIOCTL0 control register.<br/> 0 = PF.6 pin I/O function is controlled by GPIO module.<br/> Hardware auto becomes CTLSEL2 = 1 when system power is turned off.<br/> 1 = PF.6 pin I/O function is controlled by V<sub>BAT</sub> power domain.<br/> PF.6 pin function and I/O status are controlled by OPMODE2[1:0] and DOUT2 after CTLSEL2 is set to 1.</p> <p><b>Note:</b> CTLSEL2 will automatically be set by hardware to 1 when system power is off and INIT[0] (RTC_INIT[0]) is 1.</p> |
| [18]    | <b>DOUT2</b>    | <p><b>IO Output Data</b><br/> 0 = PF.6 output low.<br/> 1 = PF.6 output high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [17:16] | <b>OPMODE2</b>  | <p><b>IO Operation Mode</b><br/> 00 = PF.6 is input only mode.<br/> 01 = PF.6 is output push pull mode.<br/> 10 = PF.6 is open drain mode.<br/> 11 = PF.6 is quasi-bidirectional mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [15:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [13:12] | <b>PUSEL1</b>   | <p><b>IO Pull-up and Pull-down Enable Bits</b><br/> Determine PF.5 I/O pull-up or pull-down.<br/> 00 = PF.5 pull-up and pull-up disable.<br/> 01 = PF.5 pull-up enable.<br/> 10 = PF.5 pull-down enable.</p> <p><b>Note:</b><br/> 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.</p>                                                                                                                                                                                                                                                                                                            |
| [11]    | <b>CTLSEL1</b>  | <p><b>IO Pin State Backup Selection</b><br/> When low speed 32 kHz oscillator is disabled, PF.5 pin (X32KI pin) can be used as GPIO function.<br/> User can program CTLSEL1 to decide PF.5 I/O function is controlled by system power domain GPIO module or V<sub>BAT</sub> power domain RTC_GPIOCTL0 control register.<br/> 0 = PF.5 pin I/O function is controlled by GPIO module.<br/> Hardware auto becomes CTLSEL1 = 1 when system power is turned off.<br/> 1 = PF.5 pin I/O function is controlled by V<sub>BAT</sub> power domain.<br/> PF.5 pin function and I/O status are controlled by OPMODE1[1:0] and DOUT1 after CTLSEL1 is set to 1.</p> <p><b>Note:</b> CTLSEL1 will automatically be set by hardware to 1 when system power is off and</p>           |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | INIT[0] (RTC_INIT[0]) is 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [10]  | <b>DOUT1</b>    | <b>IO Output Data</b><br>0 = PF.5 output low.<br>1 = PF.5 output high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [9:8] | <b>OPMODE1</b>  | <b>IO Operation Mode</b><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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [7:6] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [5:4] | <b>PUSEL0</b>   | <b>IO Pull-up and Pull-down Enable Bits</b><br>Determine PF.4 I/O pull-up or pull-down.<br>00 = PF.4 pull-up and pull-down disable.<br>01 = PF.4 pull-up enable.<br>10 = PF.4 pull-down enable.<br><b>Note:</b> 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.                                                                                                                                                                                                                                                                                                                              |
| [3]   | <b>CTLSEL0</b>  | <b>IO Pin State Backup Selection</b><br>When low speed 32 kHz oscillator is disabled, PF.4 pin (X32KO pin) can be used as GPIO function. User can program CTLSEL0 to decide PF.4 I/O function is controlled by system power domain GPIO module or V <sub>BAT</sub> power domain RTC_GPIOCTL0 control register.<br>0 = PF.4 pin I/O function is controlled by GPIO module.<br>Hardware auto becomes CTLSEL0 = 1 when system power is turned off.<br>1 = PF.4 pin I/O function is controlled by V <sub>BAT</sub> power domain.<br>PF.4 pin function and I/O status are controlled by OPMODE0[1:0] and DOUT0 after CTLSEL0 is set to 1.<br><b>Note:</b> CTLSEL0 will automatically be set by hardware to 1 when system power is off and INIT[0] (RTC_INIT[0]) is 1. |
| [2]   | <b>DOUT0</b>    | <b>IO Output Data</b><br>0 = PF.4 output low.<br>1 = PF.4 output high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [1:0] | <b>OPMODE0</b>  | <b>IO Operation Mode</b><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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

RTC GPIO Control Register1 (RTC\_GPIOCTL1)

| Register     | Offset       | R/W | Description                 |  |  |  | Reset Value |
|--------------|--------------|-----|-----------------------------|--|--|--|-------------|
| RTC_GPIOCTL1 | RTC_BA+0x108 | R/W | RTC GPIO Control 1 Register |  |  |  | 0x0000_0000 |

| 31       | 30 | 29     | 28 | 27      | 26    | 25      | 24 |
|----------|----|--------|----|---------|-------|---------|----|
| Reserved |    | PUSEL7 |    | CTLSEL7 | DOUT7 | OPMODE7 |    |
| 23       | 22 | 21     | 20 | 19      | 18    | 17      | 16 |
| Reserved |    | PUSEL6 |    | CTLSEL6 | DOUT6 | OPMODE6 |    |
| 15       | 14 | 13     | 12 | 11      | 10    | 9       | 8  |
| Reserved |    | PUSEL5 |    | CTLSEL5 | DOUT5 | OPMODE5 |    |
| 7        | 6  | 5      | 4  | 3       | 2     | 1       | 0  |
| Reserved |    | PUSEL4 |    | CTLSEL4 | DOUT4 | OPMODE4 |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [29:28] | PUSEL7      | <p><b>IO Pull-up and Pull-down Enable Bits</b><br/> Determine PF.11 I/O pull-up or pull-down.<br/> 00 = PF.11 pull-up and pull-down disable.<br/> 01 = PF.11 pull-up enable.<br/> 10 = PF.11 pull-down enable.</p> <p><b>Note:</b> 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.</p>                                                                                                                                                                                                                                                                                                                  |
| [27]    | CTLSEL7     | <p><b>IO Pin State Backup Selection</b><br/> When TAMPER5EN is disabled, PF.11 pin (TAMPER5 pin) can be used as GPIO function.<br/> User can program CTLSEL7 to decide PF.11 I/O function is controlled by system power domain GPIO module or V<sub>BAT</sub> power domain RTC_GPIOCTL1 control register.<br/> 0 = PF.11 pin I/O function is controlled by GPIO module.<br/> Hardware auto becomes CTLSEL7 = 1 when system power is turned off.<br/> 1 = PF.11 pin I/O function is controlled by V<sub>BAT</sub> power domain.<br/> PF.11 pin function and I/O status are controlled by OPMODE7[1:0] and DOUT7 after CTLSEL7 is set to 1.</p> <p><b>Note:</b> CTLSEL7 will automatically be set by hardware to 1 when system power is off and INIT[0] (RTC_INIT[0]) is 1.</p> |
| [26]    | DOUT7       | <p><b>IO Output Data</b><br/> 0 = PF.11 output low.<br/> 1 = PF.11 output high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [25:24] | OPMODE7     | <p><b>IO Operation Mode</b><br/> 00 = PF.11 is input only mode.<br/> 01 = PF.11 is output push pull mode.<br/> 10 = PF.11 is open drain mode.<br/> 11 = PF.11 is quasi-bidirectional mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23:22] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [21:20] | <b>PUSEL6</b>   | <p><b>IO Pull-up and Pull-down Enable Bits</b><br/> Determine PF.10 I/O pull-up or pull-down.<br/> 00 = PF.10 pull-up and pull-down disable.<br/> 01 = PF.10 pull-up enable.<br/> 10 = PF.10 pull-down enable.</p> <p><b>Note:</b> 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.</p>                                                                                                                                                                                                                                                                                                                |
| [19]    | <b>CTLSEL6</b>  | <p><b>IO Pin State Backup Selection</b><br/> When TAMP4EN is disabled, PF.10 pin (TAMPER4 pin) can be used as GPIO function.<br/> User can program CTLSEL6 to decide PF.10 I/O function is controlled by system power domain GPIO module or V<sub>BAT</sub> power domain RTC_GPIOCTL1 control register.<br/> 0 = PF.10 pin I/O function is controlled by GPIO module.<br/> Hardware auto becomes CTLSEL6 = 1 when system power is turned off.<br/> 1 = PF.10 pin I/O function is controlled by V<sub>BAT</sub> power domain.<br/> PF.10 pin function and I/O status are controlled by OPMODE6[1:0] and DOUT6 after CTLSEL6 is set to 1.</p> <p><b>Note:</b> CTLSEL6 will automatically be set by hardware to 1 when system power is off and INIT[0] (RTC_INIT[0]) is 1.</p> |
| [18]    | <b>DOUT6</b>    | <p><b>IO Output Data</b><br/> 0 = PF.10 output low.<br/> 1 = PF.10 output high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [17:16] | <b>OPMODE6</b>  | <p><b>IO Operation Mode</b><br/> 00 = PF.10 is input only mode.<br/> 01 = PF.10 is output push pull mode.<br/> 10 = PF.10 is open drain mode.<br/> 11 = PF.10 is quasi-bidirectional mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [15:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [13:12] | <b>PUSEL5</b>   | <p><b>IO Pull-up and Pull-down Enable Bits</b><br/> Determine PF.9 I/O pull-up or pull-down.<br/> 00 = PF.9 pull-up and pull-down disable.<br/> 01 = PF.9 pull-up enable.<br/> 10 = PF.9 pull-down enable.</p> <p><b>Note:</b> 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.</p>                                                                                                                                                                                                                                                                                                                    |
| [11]    | <b>CTLSEL5</b>  | <p><b>IO Pin State Backup Selection</b><br/> When TAMP3EN is disabled, PF.9 pin (TAMPER3 pin) can be used as GPIO function.<br/> User can program CTLSEL5 to decide PF.9 I/O function is controlled by system power domain GPIO module or V<sub>BAT</sub> power domain RTC_GPIOCTL1 control register.<br/> 0 = PF.9 pin I/O function is controlled by GPIO module.<br/> Hardware auto becomes CTLSEL5 = 1 when system power is turned off.<br/> 1 = PF.9 pin I/O function is controlled by V<sub>BAT</sub> power domain.<br/> PF.9 pin function and I/O status are controlled by OPMODE5[1:0] and DOUT5 after CTLSEL5 is set to 1.</p> <p><b>Note:</b> CTLSEL5 will automatically be set by hardware to 1 when system power is off and INIT[0] (RTC_INIT[0]) is 1.</p>      |
| [10]    | <b>DOUT5</b>    | <p><b>IO Output Data</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | 0 = PF.9 output low.<br>1 = PF.9 output high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [9:8] | <b>OPMODE5</b>  | <b>IO Operation Mode</b><br>00 = PF.9 is input only mode.<br>01 = PF.9 is output push pull mode.<br>10 = PF.9 is open drain mode.<br>11 = PF.9 is quasi-bidirectional mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [7:6] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [5:4] | <b>PUSEL4</b>   | <b>IO Pull-up and Pull-down Enable Bits</b><br>Determine PF.8 I/O pull-up or pull-down.<br>00 = PF.8 pull-up and pull-down disable.<br>01 = PF.8 pull-up enable.<br>10 = PF.8 pull-down enable.<br><b>Note:</b> 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.                                                                                                                                                                                                                                                                                                               |
| [3]   | <b>CTLSEL4</b>  | <b>IO Pin State Backup Selection</b><br>When TAMP2EN is disabled, PF.8 pin (TAMPER2 pin) can be used as GPIO function.<br>User can program CTLSEL4 to decide PF.8 I/O function is controlled by system power domain GPIO module or V <sub>BAT</sub> power domain RTC_GPIOCTL1 control register.<br>0 = PF.8 pin I/O function is controlled by GPIO module.<br>Hardware auto becomes CTLSEL4 = 1 when system power is turned off.<br>1 = PF.8 pin I/O function is controlled by V <sub>BAT</sub> power domain.<br>PF.8 pin function and I/O status are controlled by OPMODE4[1:0] and DOUT4 after CTLSEL4 is set to 1.<br><b>Note:</b> CTLSEL4 will automatically be set by hardware to 1 when system power is off and INIT[0] (RTC_INIT[0]) is 1. |
| [2]   | <b>DOUT4</b>    | <b>IO Output Data</b><br>0 = PF.8 output low.<br>1 = PF.8 output high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [1:0] | <b>OPMODE4</b>  | <b>IO Operation Mode</b><br>00 = PF.8 is input only mode.<br>01 = PF.8 is output push pull mode.<br>10 = PF.8 is open drain mode.<br>11 = PF.8 is quasi-bidirectional mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**RTC Daylight Saving Time Control Register (RTC\_DSTCTL)**

| Register   | Offset       | R/W | Description                               |  |  |  |  | Reset Value |
|------------|--------------|-----|-------------------------------------------|--|--|--|--|-------------|
| RTC_DSTCTL | RTC_BA+0x110 | R/W | RTC Daylight Saving Time Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                               |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | <b>Reserved</b> | Reserved.                                                                                                                     |
| [2]    | <b>DSBAK</b>    | <b>Daylight Saving Back</b><br>0= Normal mode.<br>1= Daylight saving mode.                                                    |
| [1]    | <b>SUBHR</b>    | <b>Subtract 1 Hour</b><br>0 = No effect.<br>1 = Indicates RTC hour digit has been subtracted one hour for winter time change. |
| [0]    | <b>ADDHR</b>    | <b>Add 1 Hour</b><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_TAMPC TL | RTC_BA+0x120 | R/W | RTC Tamper Pin Control Register |  |  |  | 0x0000_0000 |

| 31       | 30        | 29      | 28      | 27       | 26        | 25      | 24      |
|----------|-----------|---------|---------|----------|-----------|---------|---------|
| DYNPR2EN | TAMP5DBEN | TAMP5LV | TAMP5EN | Reserved | TAMP4DBEN | TAMP4LV | TAMP4EN |
| 23       | 22        | 21      | 20      | 19       | 18        | 17      | 16      |
| DYNPR1EN | TAMP3DBEN | TAMP3LV | TAMP3EN | Reserved | TAMP2DBEN | TAMP2LV | TAMP2EN |
| 15       | 14        | 13      | 12      | 11       | 10        | 9       | 8       |
| DYNPR0EN | TAMP1DBEN | TAMP1LV | TAMP1EN | Reserved | TAMP0DBEN | TAMP0LV | TAMP0EN |
| 7        | 6         | 5       | 4       | 3        | 2         | 1       | 0       |
| DYNRATE  |           |         | SEEDRLD | DYNNSRC  |           | DYN2ISS | DYN1ISS |

| Bits | Description |                                                                                                                                                                                           |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31] | DYNPR2EN    | <b>Dynamic Pair 2 Enable Bit</b><br>0 = Static detect.<br>1 = Dynamic detect.                                                                                                             |
| [30] | TAMP5DBEN   | <b>Tamper 5 De-bounce Enable Bit</b><br>0 = Tamper 5 de-bounce Disabled.<br>1 = Tamper 5 de-bounce Enabled.                                                                               |
| [29] | TAMP5LV     | <b>Tamper 5 Level</b><br>This bit depends on level attribute of tamper pin for static tamper detection.<br>0 = Detect voltage level is low.<br>1 = Detect voltage level is high.          |
| [28] | TAMP5EN     | <b>Tamper 5 Detect Enable Bit</b><br>0 = Tamper 5 detect Disabled.<br>1 = Tamper 5 detect Enabled.<br><b>Note:</b> The reference is RTC-clock. Tamper detector need sync 2 ~ 3 RTC-clock. |
| [27] | Reserved    | Reserved.                                                                                                                                                                                 |
| [26] | TAMP4DBEN   | <b>Tamper 4 De-bounce Enable Bit</b><br>0 = Tamper 4 de-bounce Disabled.<br>1 = Tamper 4 de-bounce Enabled.                                                                               |
| [25] | TAMP4LV     | <b>Tamper 4 Level</b><br>This bit depends on level attribute of tamper pin for static tamper detection.<br>0 = Detect voltage level is low.<br>1 = Detect voltage level is high.          |
| [24] | TAMP4EN     | <b>Tamper4 Detect Enable Bit</b><br>0 = Tamper 4 detect Disabled.<br>1 = Tamper 4 detect Enabled.                                                                                         |

|      |                  |                                                                                                                                                                                            |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  | <b>Note1:</b> The reference is RTC-clock. Tamper detector need sync 2 ~ 3 RTC-clock.                                                                                                       |
| [23] | <b>DYNPR1EN</b>  | <b>Dynamic Pair 1 Enable Bit</b><br>0 = Static detect.<br>1 = Dynamic detect.                                                                                                              |
| [22] | <b>TAMP3DBEN</b> | <b>Tamper 3 De-bounce Enable Bit</b><br>0 = Tamper 3 de-bounce Disabled.<br>1 = Tamper 3 de-bounce Enabled.                                                                                |
| [21] | <b>TAMP3LV</b>   | <b>Tamper 3 Level</b><br>This bit depends on level attribute of tamper pin for static tamper detection.<br>0 = Detect voltage level is low.<br>1 = Detect voltage level is high.           |
| [20] | <b>TAMP3EN</b>   | <b>Tamper 3 Detect Enable Bit</b><br>0 = Tamper 3 detect Disabled.<br>1 = Tamper 3 detect Enabled.<br><b>Note1:</b> The reference is RTC-clock. Tamper detector need sync 2 ~ 3 RTC-clock. |
| [19] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                  |
| [18] | <b>TAMP2DBEN</b> | <b>Tamper 2 De-bounce Enable Bit</b><br>0 = Tamper 2 de-bounce Disabled.<br>1 = Tamper 2 de-bounce Enabled.                                                                                |
| [17] | <b>TAMP2LV</b>   | <b>Tamper 2 Level</b><br>This bit depends on level attribute of tamper pin for static tamper detection.<br>0 = Detect voltage level is low.<br>1 = Detect voltage level is high.           |
| [16] | <b>TAMP2EN</b>   | <b>Tamper 2 Detect Enable Bit</b><br>0 = Tamper 2 detect Disabled.<br>1 = Tamper 2 detect Enabled.<br><b>Note1:</b> The reference is RTC-clock. Tamper detector need sync 2 ~ 3 RTC-clock. |
| [15] | <b>DYNPR0EN</b>  | <b>Dynamic Pair 0 Enable Bit</b><br>0 = Static detect.<br>1 = Dynamic detect.                                                                                                              |
| [14] | <b>TAMP1DBEN</b> | <b>Tamper 1 De-bounce Enable Bit</b><br>0 = Tamper 1 de-bounce Disabled.<br>1 = Tamper 1 de-bounce Enabled.                                                                                |
| [13] | <b>TAMP1LV</b>   | <b>Tamper 1 Level</b><br>This bit depends on level attribute of tamper pin for static tamper detection.<br>0 = Detect voltage level is low.<br>1 = Detect voltage level is high.           |
| [12] | <b>TAMP1EN</b>   | <b>Tamper 1 Detect Enable Bit</b><br>0 = Tamper 1 detect Disabled.<br>1 = Tamper 1 detect Enabled.<br><b>Note1:</b> The reference is RTC-clock. Tamper detector need sync 2 ~ 3 RTC-clock. |
| [11] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                  |
| [10] | <b>TAMP0DBEN</b> | <b>Tamper 0 De-bounce Enable Bit</b><br>0 = Tamper 0 de-bounce Disabled.                                                                                                                   |

|       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         | 1 = Tamper 0 de-bounce Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [9]   | TAMP0LV | <p><b>Tamper 0 Level</b><br/>           This bit depends on level attribute of tamper pin for static tamper detection.<br/>           0 = Detect voltage level is low.<br/>           1 = Detect voltage level is high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [8]   | TAMPOEN | <p><b>Tamper0 Detect Enable Bit</b><br/>           0 = Tamper 0 detect Disabled.<br/>           1 = Tamper 0 detect Enabled.<br/> <b>Note1:</b> The reference is RTC-clock. Tamper detector need sync 2 ~ 3 RTC-clock.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [7:5] | DYNRATE | <p><b>Dynamic Change Rate</b><br/>           This item is choice the dynamic tamper output change rate.<br/>           000 = <math>2^{10}</math> * RTC_CLK.<br/>           001 = <math>2^{11}</math> * RTC_CLK.<br/>           010 = <math>2^{12}</math> * RTC_CLK.<br/>           011 = <math>2^{13}</math> * RTC_CLK.<br/>           100 = <math>2^{14}</math> * RTC_CLK.<br/>           101 = <math>2^{15}</math> * RTC_CLK.<br/>           110 = <math>2^{16}</math> * RTC_CLK.<br/>           111 = <math>2^{17}</math> * RTC_CLK.<br/> <b>Note:</b> After revising this field, set SEEDRLD (RTC_TAMPCTL[4]) can reload change rate immediately.</p> |
| [4]   | SEEDRLD | <p><b>Reload New Seed for PRNG Engine</b><br/>           Setting this bit, the tamper configuration will be reload.<br/>           0 = Generating key based on the current seed.<br/>           1 = Reload new seed.<br/> <b>Note:</b> Before this bit is set, the tamper configuration should be set to complete.</p>                                                                                                                                                                                                                                                                                                                                    |
| [3:2] | DYNSRC  | <p><b>Dynamic Reference Pattern</b><br/>           This fields determine the new reference pattern when current pattern run out in dynamic pair mode.<br/>           00 or 10 = The new reference pattern is generated by random number generator when the reference pattern run out.<br/>           01 = The new reference pattern is repeated previous random value when the reference pattern run out.<br/>           11 = The new reference pattern is repeated from SEED (RTC_TAMPSEED[31:0]) when the reference pattern run out.<br/> <b>Note:</b> After this bit is modified, the SEEDRLD (RTC_TAMPCTL[4]) should be set.</p>                      |
| [1]   | DYN2ISS | <p><b>Dynamic Pair 2 Input Source Select</b><br/>           This bit determine Tamper 5 input is from Tamper 4 or Tamper 0 in dynamic mode.<br/>           0 = Tamper input is from Tamper 4.<br/>           1 = Tamper input is from Tamper 0.<br/> <b>Note:</b> This bit has effect only when DYNPR2EN (RTC_TAMPCTL[24]) and DYNPROEN (RTC_TAMPCTL[15]) are set</p>                                                                                                                                                                                                                                                                                     |
| [0]   | DYN1ISS | <p><b>Dynamic Pair 1 Input Source Select</b><br/>           This bit determine Tamper 3 input is from Tamper 2 or Tamper 0 in dynamic mode.<br/>           0 = Tamper input is from Tamper 2.<br/>           1 = Tamper input is from Tamper 0.<br/> <b>Note:</b> This bit is effective only when DYNPR1EN (RTC_TAMPCTL[16]) and DYNPROEN (RTC_TAMPCTL[15]) are set</p>                                                                                                                                                                                                                                                                                   |

**RTC Tamper Dynamic Seed Register (RTC\_TAMPSEED)**

| Register     | Offset       | R/W | Description                      | Reset Value |
|--------------|--------------|-----|----------------------------------|-------------|
| RTC_TAMPSEED | RTC_BA+0x128 | R/W | RTC Tamper Dynamic Seed Register | 0x0000_0000 |

|      |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|
| 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        | Seed Value |

**RTC Tamper Time Register (RTC\_TAMPTIME)**

| Register     | Offset       | R/W | Description              | Reset Value |
|--------------|--------------|-----|--------------------------|-------------|
| RTC_TAMPTIME | RTC_BA+0x130 | R   | RTC Tamper Time Register | 0x0000_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:24] | Reserved    | Reserved.                                                                        |
| [21:20] | TENHR       | 10-hour Time Digit of TAMPER Time (0~2)<br><b>Note:</b> 24-hour time scale only. |
| [19:16] | HR          | 1-Hour Time Digit of TAMPER Time (0~9)                                           |
| [15]    | Reserved    | Reserved.                                                                        |
| [14:12] | TENMIN      | 10-Min Time Digit of TAMPER Time (0~5)                                           |
| [11:8]  | MIN         | 1-Min Time Digit of TAMPER Time (0~9)                                            |
| [7]     | Reserved    | Reserved.                                                                        |
| [6:4]   | TENSEC      | 10-Sec Time Digit of TAMPER Time (0~5)                                           |
| [3:0]   | SEC         | 1-Sec Time Digit of TAMPER Time (0~9)                                            |

**Note:**

1. RTC\_TALM is a BCD digit counter.
2. The reasonable value range is listed in the parenthesis.
3. This fields can't update until all TAMPxFIF are cleared.

RTC Tamper Calendar Register (RTC\_TAMPCAL)

| Register    | Offset       | R/W | Description                  | Reset Value |
|-------------|--------------|-----|------------------------------|-------------|
| RTC_TAMPCAL | RTC_BA+0x134 | R   | RTC Tamper Calendar Register | 0x0000_0000 |

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

| Bits    | Description |                                                  |
|---------|-------------|--------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                        |
| [23:20] | TENYEAR     | 10-Year Calendar Digit of TAMPER Calendar (0~9)  |
| [19:16] | YEAR        | 1-Year Calendar Digit of TAMPER Calendar (0~9)   |
| [15:13] | Reserved    | Reserved.                                        |
| [12]    | TENMON      | 10-Month Calendar Digit of TAMPER Calendar (0~1) |
| [11:8]  | MON         | 1-Month Calendar Digit of TAMPER Calendar (0~9)  |
| [7:6]   | Reserved    | Reserved.                                        |
| [5:4]   | TENDAY      | 10-Day Calendar Digit of TAMPER Calendar (0~3)   |
| [3:0]   | DAY         | 1-Day Calendar Digit of TAMPER Calendar (0~9)    |

**Note:**

1. RTC\_CTAMP is a BCD digit counter.
2. The reasonable value range is listed in the parenthesis.
3. This fields can't be updated until all TAMPxIF are cleared.

## 6.11 EPWM Generator and Capture Timer (EPWM)

### 6.11.1 Overview

The chip provides two EPWM generators — EPWM0 and EPWM1. Each EPWM supports 6 channels of EPWM output or input capture. There is a 12-bit prescaler to support flexible clock to the 16-bit EPWM counter with 16-bit comparator. The EPWM counter supports up, down and up-down counter types. EPWM uses comparator compared with counter to generate events. These events use to generate EPWM pulse, interrupt and trigger signal for EADC/DAC to start conversion.

The EPWM generator supports two standard EPWM output modes: Independent mode and Complementary mode, they have difference architecture. There are two output functions based on standard output modes: Group function and Synchronous function. Group function can be enabled under Independent mode or complementary mode. Synchronous function only enabled under complementary mode. Complementary mode has two comparators to generate various EPWM pulse with 12-bit dead-time generator and another free trigger comparator to generate trigger signal for EADC. For EPWM output control unit, it supports polarity output, independent pin mask and brake functions.

The EPWM generator also supports input capture function. It supports latch EPWM counter value to corresponding register when input channel has a rising transition, falling transition or both transition is happened. Capture function also support PDMA to transfer captured data to memory.

### 6.11.2 Features

#### 6.11.2.1 EPWM Function Features

- Supports maximum clock frequency up to maximum PLL frequency
- Supports up to two EPWM modules, each module provides 6 output channels
- Supports independent mode for EPWM output/Capture input channel
- Supports complementary mode for 3 complementary paired EPWM output channel
  - Dead-time insertion with 12-bit resolution
  - Synchronous function for phase control
  - Two compared values during one period
- Supports 12-bit prescaler from 1 to 4096
- Supports 16-bit resolution EPWM counter
  - Up, down and up/down counter operation type
- Supports one-shot or auto-reload counter operation mode
- Supports group function
- Supports synchronous function
- Supports mask function and tri-state enable for each EPWM pin
- Supports brake function
  - Brake source from pin, analog comparator and system safety events (clock failed, SRAM parity error, Brown-out detection and CPU lockup).
  - Noise filter for brake source from pin
  - Leading edge blanking (LEB) function for brake source from analog comparator
  - Edge detect brake source to control brake state until brake interrupt cleared
  - Level detect brake source to auto recover function after brake condition removed

- Supports interrupt on the following events:
  - EPWM counter matches 0, period value or compared value
  - Brake condition happened
- Supports trigger EADC/DAC on the following events:
  - EPWM counter matches 0, period value or compared value
  - EPWM counter match free trigger comparator compared value (only for EADC)

#### 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
- Supports PDMA transfer function for EPWM all channels

#### 6.11.3 Block Diagram



Figure 6.11-1 EPWM Generator Overview Block Diagram

EPWM Clock frequency can be set equal or double to PCLK frequency as Figure 6.11-2. For the detailed register setting, please refer to Table 6.11-1. Each EPWM generator has three clock source inputs, each clock source can be selected from EPWM Clock or four TIMER trigger EPWM outputs as Figure 6.11-3 by ECLKSRC0 (EPWM\_CLKSRC[2:0]) for EPWM\_CLK0, ECLKSRC2 (EPWM\_CLKSRC[10:8]) for EPWM\_CLK2 and ECLKSRC4 (EPWM\_CLKSRC[18:16]) for EPWM\_CLK4.



Figure 6.11-2 EPWM Clock Source Control

| Frequency Ratio<br>PCLK:EPWM<br>Clock | HCLK  | PCLK  | EPWM<br>Clock | HCLKSEL<br>CLK_CLKSEL0[2:0] | HCLKDIV<br>CLK_CLKDIV0[3:<br>0] | APBnDIV<br>(CLK_PCLKDIV<br>n<br>[2+4n:4n]),<br>N Denotes 0 Or<br>1 | EPWMnSEL<br>(CLK_CLKSEL2[N])<br>,<br>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.11-1 EPWM Clock Source Control Registers Setting Table



Figure 6.11-3 EPWM Clock Source Control

Figure 6.11-4 and Figure 6.11-5 illustrate the architecture of EPWM independent mode and complementary mode. No matter independent mode or complementary mode, paired channels' (EPWM\_CH0 and EPWM\_CH1, EPWM\_CH2 and EPWM\_CH3, EPWM\_CH4 and EPWM\_CH5) counters both come from the same clock source and prescaler. When counter count to 0, PERIOD (EPWM\_PERIODn[15:0]) or equal to comparator, events will be generated. These events are passed to corresponding generators to generate EPWM pulse, interrupt signal and trigger signal for EADC/DAC to start conversion. Output control is used to changing EPWM pulse output state; brake function in output control also generates interrupt events. In complementary mode, synchronize function is available and even channel use odd channel comparator to generate events, free trigger comparator events only use to generate trigger EADC signals.



Figure 6.11-4 EPWM Independent Mode Architecture Diagram



Figure 6.11-5 EPWM Complementary Mode Architecture Diagram

#### 6.11.4 Basic Configuration

##### 6.11.4.1 EPWM0 Basic Configuration

- Clock Source Configuration
  - Select the source of EPWM0 peripheral clock on EPWM0SEL (CLK\_CLKSEL2[0])
  - Enable EPWM0 peripheral clock in EPWM0CKEN CLK\_APBCLK1[16]).
- Reset Configuration
  - Reset EPWM0 in EPWM0RST SYS\_IPRST2[16]
- Pin Configuration

| Group | Pin Name     | GPIO       | MFP   |
|-------|--------------|------------|-------|
| EPWM0 | EPWM0_BRAKE0 | PE.8       | MFP11 |
|       |              | PB.1       | MFP13 |
|       | EPWM0_BRAKE1 | PE.9       | MFP11 |
|       |              | PB.0       | MFP13 |
|       | EPWM0_CH0    | PE.8       | MFP10 |
|       |              | PB.5, PG.8 | MFP11 |

|                |             |       |
|----------------|-------------|-------|
| EPWM0_CH1      | PE.7        | MFP12 |
|                | PA.5        | MFP13 |
|                | PE.9        | MFP10 |
|                | PB.4, PG.7  | MFP11 |
|                | PE.6        | MFP12 |
|                | PA.4        | MFP13 |
|                | PE.10       | MFP10 |
|                | PB.3, PG.6  | MFP11 |
|                | PE.5        | MFP12 |
|                | PA.3        | MFP13 |
| EPWM0_CH2      | PE.11       | MFP10 |
|                | PB.2, PG.5  | MFP11 |
|                | PE.4        | MFP12 |
|                | PA.2        | MFP13 |
| EPWM0_CH3      | PE.12       | MFP10 |
|                | PB.1, PD.14 | MFP11 |
|                | PE.3        | MFP12 |
|                | PA.1        | MFP13 |
| EPWM0_CH4      | PE.13       | MFP10 |
|                | PB.0, PH.11 | MFP11 |
|                | PE.2        | MFP12 |
|                | PA.0        | MFP13 |
| EPWM0_SYNC_IN  | PC.14       | MFP11 |
|                | PA.15       | MFP12 |
| EPWM0_SYNC_OUT | PF.5        | MFP9  |
|                | PA.11       | MFP10 |

#### 6.11.4.2 EPWM1 Basic Configuration

- Clock Source Configuration
  - Select the source of EPWM1 peripheral clock on EPWM1SEL (CLK\_CLKSEL2[1])
  - Enable EPWM1 peripheral clock in EPWM1CKEN (CLK\_APBCLK1[17]).
- Reset Configuration
  - Reset EPWM1 in EPWM1RST SYS\_IPRST2[17]
- Pin Configuration

| Group | Pin Name | GPIO | MFP |
|-------|----------|------|-----|
|-------|----------|------|-----|

|       |              |                  |       |
|-------|--------------|------------------|-------|
| EPWM1 | EPWM1_BRAKE0 | PB.7, PE.10      | MFP11 |
|       | EPWM1_BRAKE1 | PB.6, PE.11      | MFP11 |
|       | EPWM1_CH0    | PB.15, PE.13     | MFP11 |
|       |              | PC.5, PC.12      | MFP12 |
|       | EPWM1_CH1    | PB.14, PC.8      | MFP11 |
|       |              | PC.4, PC.11      | MFP12 |
|       | EPWM1_CH2    | PB.13, PC.7      | MFP11 |
|       |              | PC.3, PC.10      | MFP12 |
|       | EPWM1_CH3    | PB.12, PC.6      | MFP11 |
|       |              | PC.2, PC.9       | MFP12 |
|       | EPWM1_CH4    | PA.7             | MFP11 |
|       |              | PB.1, PB.7, PC.1 | MFP12 |
|       | EPWM1_CH5    | PA.6             | MFP11 |
|       |              | PB.0, PB.6, PC.0 | MFP12 |

### 6.11.5 Functional Description

#### 6.11.5.1 EPWM Prescaler

The EPWM prescaler is used to divide clock source, prescaler counting CLKPSC +1 times, EPWM counter only count once. The prescale double buffer is setting by CLKPSC (EPWM\_CLKPSCn[11:0], n = 0, 2, 4) bits. Figure 6.11-6 is an example of EPWM channel 0 prescale waveform. The prescale counter will reload CLKPSC at the begin of the next prescale counter down-count.



Figure 6.11-6 EPWM\_CH0 Prescaler Waveform in Up Counter Type

#### 6.11.5.2 EPWM Counter

The EPWM supports 3 counter types operation: Up Counter, Down Counter and Up-Down Counter types.

For EPWM channel0, CNT(EPWM\_CNT0[15:0]) can clear to 0x00 by CNTCLR0 (EPWM\_CNTCLR[0]). CNT will be cleared when prescale counter count to 0, and CNTCLR will be set 0 by hardware automatically.



Figure 6.11-7 EPWM Counter Waveform when Setting Clear Counter

#### 6.11.5.3 Up Counter Type

When EPWM counter is set to up counter type, CNTTYPE<sub>n</sub> (EPWM\_CTL1[2n+1:2n], n = 0,1..5) is 0x0, it starts up-counting from 0 to PERIOD (EPWM\_PERIOD<sub>n</sub>[15:0], where n denotes channel number) to complete a EPWM period. The current counter value can be read from CNT (EPWM\_CNT<sub>n</sub>[15:0]) bits. EPWM generates zero point event when the counter counts to 0 and prescale counts to 0. EPWM generates period point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.11-8 shows an example of up counter, wherein

$$\text{EPWM period time} = (\text{PERIOD}+1) * (\text{CLKPSC}+1) * \text{EPWMx\_CLK}.$$



Figure 6.11-8 EPWM Up Counter Type

#### 6.11.5.4 Down Counter Type

When EPWM counter is set to down counter type, CNTTYPE<sub>n</sub> (EPWM\_CTL1[2n+1:2n], n = 0,1..5) is 0x1, it starts down-counting from PERIOD to 0 to complete a EPWM period. The current counter value can be read from CNT (EPWM\_CNT<sub>n</sub>[15:0]) bits. EPWM generates zero point event when the counter counts to 0 and prescale counts to 0. EPWM generates period point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.11-9 shows an example of down counter, wherein

EPWM period time = (PERIOD+1) \* (CLKPSC+1) \* EPWMx\_CLK.



Figure 6.11-9 EPWM Down Counter Type

#### 6.11.5.5 Up-Down Counter Type

When EPWM counter is set to up-down count type, CNTTYPE<sub>n</sub> (EPWM\_CTL1[2n+1:2n], n = 0,1..5) is 0x2, it starts counting-up from 0 to PERIOD and then starts counting down to 0 to complete a EPWM period. The current counter value can be read from CNT (EPWM\_CNTn[15:0]) bits. EPWM generates zero point event when the counter counts to 0 and prescale counts to 0. EPWM generates center point event which is equal to period point event when the counter counts to PERIOD. Figure 6.11-10 shows an example of up-down counter, wherein

EPWM period time = (2\*PERIOD) \* (CLKPSC+1) \* EPWMx\_CLK.

The DIRF (EPWM\_CNTn[16]) bit is counter direction indicator flag, where high is up counting, and low is down counting.



Figure 6.11-10 EPWM Up-Down Counter Type

#### 6.11.5.6 EPWM Comparator

There are two kinds of comparator registers : one is CMPDATn( $n = 0,1..5$ ), and the other is FTCMPDATn\_m( $n = 0,2,4$ ,  $m = 1,3,5$ ) register. CMPDATn is a basic comparator register of EPWM 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, EPWM generates a compared point event and uses the event to generate EPWM pulse, interrupt or use to trigger EADC/DAC. In up-down counter type, two events will be generated in a EPWM period as shown in Figure 6.11-11. The CMPU is up count compared point event and CMPD is down count compared point event.



Figure 6.11-11 EPWM Compared point Events in Up-Down Counter Type

FTCMPDAT is a free trigger comparator register. Each complementary paired channel only supports one free trigger comparator. The value of FTCMPDAT<sub>n,m</sub>(n = 0,2,4, m = 1,3,5) register is continuously compared to even channel's counter value. When counter is equal to the value of FTCMPDAT register, FTCMD<sub>n</sub> (EPWM\_FTCI[10:8], n=0,2,4) indicator is set in down count type and FTCMU<sub>n</sub> (EPWM\_FTCI[2:0], n=0,2,4) indicator is set in up count type. In addition, EPWM generates an event and only uses to trigger EADC.

#### 6.11.5.7 EPWM Double Buffering

The double buffering uses double buffers to separate software writing and hardware action operation timing. There are four loading modes for loading values to buffer: period loading mode, immediately loading mode, window loading mode and center loading mode. After registers are modified through software, hardware will load register value to the buffer register according to the loading mode timing. The hardware action is based on the buffer value. This can prevent asynchronously operation problem due to software and hardware asynchronism.

The EPWM provides PBUF (EPWM\_PBUFn[15:0]) as the active PERIOD buffer register, CMPBUF (EPWM\_CMPBUFn[15:0]) as the active CMPDAT buffer register, FTCMPBUF (EPWM\_FTCCMPBUFn\_m[15:0]) as the active FTCMPDAT buffer register and CPSCBUF (EPWM\_CPSBUF\_m[15:0]) as the active CLKPSC buffer register. The concept of double buffering is used in loading modes, which are described in the following sections. For example, as shown Figure 6.11-12, in period loading mode, writing PERIOD, CMPDAT and FTCMPDAT registers through software, EPWM will load new values to their buffer PBUF (EPWM\_PBUFn[15:0]), CMPBUF (EPWM\_CMPBUFn[15:0]) and FTCMPBUF (EPWM\_FTCCBUF[15:0]) at start of the next period without affecting the current period counter operation. FTCMPU denotes up-count free trigger compared point event and FTCMPD denotes down-count free trigger compared event.



Figure 6.11-12 EPWM Double Buffering Illustration

#### 6.11.5.8 Period Loading Mode

When immediately loading mode, window loading mode and center loading mode are disabled that IMMLDENn bits, WINLDENn bits and CTRLDn bits of EPWM\_CTL0 register are set to 0, EPWM operates at period Loading mode. In period Loading mode, CLKPSC(EPWM\_CLKPSCn\_m[11:0]), PERIOD(EPWM\_PERIODn[15:0]), CMP(EPWM\_CMPDATn[15:0]) and FTCMPDAT (EPWM\_FTCMPDATn\_m[15:0]) will all load to their active CPSCBUF, PBUF. CMPBUF and FTCMPBUF registers while each period is completed. For example, after EPWM counter up counts from 0 to PERIOD in the up-counter operation or down counts from PERIOD to 0 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.11-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.11-13. User can know the PERIOD and CMPDAT update condition, by watching EPWM 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 EPWM 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 EPWM 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 EPWM period at point 6.



Figure 6.11-13 Period Loading in Up-Count Mode

#### 6.11.5.9 Immediately Loading Mode

If the IMMLDENn (EPWM\_CTL0[21:16]) bit is set to 1, EPWM operates at immediately loading mode. In immediately loading mode, when user update CLKPSC(EPWM\_CLKPSCn\_m[11:0]), PERIOD(EPWM\_PERIODn[15:0]), CMP(EPWM\_CMPDATn[15:0]), or FTCMPDAT (EPWM\_FTCDATn\_m[15:0]), CLKPSC, PERIOD, CMPDAT or FTCMPDAT will be load to active CPSCBUF (EPWM\_CPSBUFn\_m[15:0]), PBUF (EPWM\_PBUFn[15:0]), CMPBUF (EPWM\_CMPBUFn[15:0]) or FTCMPBUF (EPWM\_FTBUF[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(EPWMx\_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.11-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.11-14 Immediately Loading in Up-Count Mode

#### 6.11.5.10 Window Loading Mode

When the WINLDENn (EPWM\_CTL0[13:8]) bit is set to 1, EPWM operates at window loading mode. In Window loading mode, CLKPSC(EPWM\_CLKPSCn\_m[11:0]), PERIOD(EPWM\_PERIODn[15:0]) and CMP(EPWM\_CMPDATn[15:0]) will all load to their active CPSCBUF, PBUF and CMPBUF registers while each period is completed, but CMPBUF loading are valid only when load window is opened. Every channel n's load window is opened by setting the corresponding LOADn (EPWM\_LOAD[5:0]) to 1, and hardware will close the window at the end of EPWM period. Figure 6.11-15 shows an example and its steps sequence is described below.

1. Software writes CMPDAT DATA1 at point 1, and the load window is not opened at this period so CMPDAT will not load to CMPBUF.
2. Software writes LOAD to open the load window at point2.
3. Software writes PERIOD DATA1 at point 3.
4. At point 4, load window has been opened, hardware loads CLKPSC DATA1, PERIOD DATA1 and CMPDAT DATA1 to their buffer and closes the load window at the end of EPWM period.
5. Software writes PERIOD DATA2 at point 5.
6. Hardware loads CLKPSC DATA2 and PERIOD DATA2 to their buffer at the end of EPWM period at point 6.
7. Software writes PERIOD DATA3 at point 7.
8. Software writes LOAD to open the load window at point8.
9. Hardware loads CLKPSC DATA3 and PERIOD DATA3 to their buffer and closes the load window at the end of EPWM period at point 9.



Figure 6.11-15 Window Loading in Up-Count Mode

#### 6.11.5.11 Center Loading Mode

When the CTLRDn (EPWM\_CTL0[5:0]) bit is set to 1 and EPWM counter is set to up-down count type, CNTTYPEEn (EPWM\_CTL1[2n+1:2n], n = 0,1..5) is 0x2, EPWM operates at center loading mode. In center loading mode, CMP(EPWM\_CMPDATn[15:0]) will load to active CMPBUF register in center of each period, that is, counter counts to PERIOD. CLKPSC(EPWM\_CLKPSCn\_m[11:0]) and PERIOD(EPWM\_PERIODn[15:0]) will all load to their active CPSCBUF and PBUF registers while each period is completed. Center loading mode can work with window loading mode, the CMP(EPWM\_CMPDATn[15:0]) will load to active CMPBUF register in center of each period, but it is valid only at the interval of load window. Figure 6.11-16 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 EPWM period at point 2.
3. Software writes PERIOD DATA1 at point 3.
4. Hardware loads PERIOD DATA1 to PBUF at the end of EPWM period at point 4.
5. Software writes CMPDAT DATA2 at point 5.
6. Hardware loads CMPDAT DATA2 to CMPBUF at center of EPWM period at point 6.
7. Software writes PERIOD DATA2 at point 7.
8. Hardware loads PERIOD DATA2 to PBUF at the end of EPWM period at point 8.



Figure 6.11-16 Center Loading in Up-Down-Count Mode

#### 6.11.5.12 EPWM Counter Operation Mode

The EPWM counter supports two operation modes: One-shot mode and Auto-reload mode. EPWM counter will operate in One-shot mode if CNTMODEn (EPWM\_CTL1[21:16]) bit is set to 1, and operate in Auto-reload mode if set to 0.

In One-shot mode, CMPDAT and PERIOD registers should be written first and then set CNTENEn (EPWM\_CNTEN[5:0]) bit as 1 to enable EPWM prescaler and counter start running. After EPWM counter counted a period, counter value will keep 0.

User can re-start next one-shot by writing new value to CMP(EPWM\_CMPDATn[15:0]) bits. If one-shot counter still running, to update CMPDAT register will cause next one-shot as continuous one-shot. Besides, to write CMPDAT register twice under continuous one-shot operation, latest value in CMPDAT register is valid at next one-shot period and only generate one-shot pulse once. Moreover, if user wants to clear counter within one-shot operation and starts next one-shot, user should monitor counter value to check counter has cleared and then writes CMPDAT register. Figure 6.11-17 is an example and following is steps sequence.

1. Software writes PERIOD DATA1 and hardware immediately loading PERIOD DATA1 to PBUF at point 1.
2. Software writes CMPDAT DATA1 which is equal to CMPDAT DATA0 at point 2 and hardware immediately loading CMPDAT DATA1 to CMPBUF, this event also trigger one-shot.
3. Software writes CMPDAT DATA2 and re-trigger next one-shot (continuous one-shot) at point 3.
4. Software writes CMPDAT DATA3 to cover CMPDAT DATA2 and re-trigger next one-shot at point 4.
5. Period loading CMPDAT DATA3 to CMPBUF at point 5.
6. There are no new CMPDAT write in the previous period, and the counter value is kept as 0 at point 6.



In Auto-reload mode, CMPDAT and PERIOD registers should be written first and then the CNTENn(EPWM\_CNTEN[n]) bit is set to 1 to enable EPWM prescaler and start to run counter. The value of CLKPSC(EPWM\_CLKPSCn\_m[11:0]), PERIOD(EPWM\_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, EPWM counter will be set to 0.

#### 6.11.5.13 EPWM Pulse Generator

The EPWM pulse generator uses counter and comparator events to generate EPWM 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 EPWM waveform to do nothing (X), set Low (L), set High (H) or toggle (T) by setting the EPWM\_WGCTL0 and EPWM\_WGCTL1 registers. Using these points can easily generate asymmetric EPWM pulse or variant waveform as shown in Figure 6.11-18. In the figure, EPWM is in complementary mode, there are two comparators n and m to generate EPWM pulse. n denotes even channel number 0, 2, or 4, and m denotes odd channel number 1, 3, or 5. n channel and m channel are complementary paired. Complementary mode uses two channels (CH0 and CH1, CH2 and CH3, or CH4 and CH5) as a pair of EPWM outputs to generate complement paired waveforms. CMPU denotes CNT(EPWM\_CNTn[15:0]) is equal to CMP(EPWM\_CMPDATn[15:0]) when counting up. CMPD denotes CNT bits is equal to CMP bits when counting down.



Figure 6.11-18 EPWM Pulse Generation

The generation events may sometimes set to the same value, as the reason, events priority between different counter types are listed 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-19.



Figure 6.11-19 EPWM 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.11-2 EPWM Pulse Generation Event Priority for Up-Counter

| Priority    | 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.11-3 EPWM Pulse Generation Event Priority for Down-Counter

| Priority    | Up Event                                       | Down Event                                       |
|-------------|------------------------------------------------|--------------------------------------------------|
| 1 (Highest) | Compare up event of odd channel (CNT = CMPUm)  | Compare down event of odd channel (CNT = CMPDm)  |
| 2           | Compare up event of even channel (CNT = CMPUn) | Compare down event of even channel (CNT = CMPDn) |
| 3           | Zero event (CNT = 0)                           | Period (center) event (CNT = PERIOD)             |

Table 6.11-4 EPWM Pulse Generation Event Priority for Up-Down-Counter

#### 6.11.5.14 EPWM Output Mode

The EPWM 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.11.5.15 Independent mode

By default, the EPWM is operating in independent mode, independent mode is enabled when channel n corresponding EPWMMODEn (EPWM\_CTL1[26:24]) bit is set to 0. In this mode six EPWM channels: EPWM\_CH0, EPWM\_CH1, EPWM\_CH2, EPWM\_CH3, EPWM\_CH4 and EPWM\_CH5 are running off its own period and duty as shown in Figure 6.11-20.



Figure 6.11-20 EPWM Independent Mode Waveform

#### 6.11.5.16 Complementary Mode

Complementary mode is enabled when the pair channel corresponding EPWMMODEn (EPWM\_CTL1[26:24]) bit set to 1. In this mode there are 3 EPWM generators utilized for complementary mode, with total of 3 EPWM output paired pins in this module. In Complimentary modes, the internal odd EPWM signal must always be the complement of the corresponding even EPWM signal. EPWM\_CH1 will be the complement of EPWM\_CH0. EPWM\_CH3 will be the complement of EPWM\_CH2 and EPWM\_CH5 will be the complement of EPWM\_CH4 as shown in Figure 6.11-21.



Figure 6.11-21 EPWM Complementary Mode Waveform

#### 6.11.5.17 EPWM Output Function

Based on the output mode, there are two output functions: group and synchronous functions for advanced output control. Group function, forces the EPWM\_CH2 and EPWM\_CH4 synchronous with EPWM\_CH0 generator and forces the EPWM\_CH3 and EPWM\_CH5 synchronous with EPWM\_CH1, may simplify updating duty control in DC and BLDC motor applications. Besides, Synchronous function makes any channel of EPWM0 and EPWM1 in phase, user can control phase value and direction.

#### 6.11.5.18 Group Function

Group function is enabled when GROUPEN (EPWM\_CTL0[24]) is set to 1, no matter in independent or complementary mode. This control allows all even EPWM channels output to be controllable by EPWM\_PERIOD0 and EPWM\_CMPDAT0 registers and all odd EPWM channels output to be controllable by EPWM\_PERIOD1 and EPWM\_CMPDAT1 registers. That is, user only needs to set EPWM\_CH0 to get EPWM\_CH0, EPWM\_CH2 and EPWM\_CH4 output the same pulse, and set EPWM\_CH1 to get EPWM\_CH1, EPWM\_CH3 and EPWM\_CH5 output the same pulse, as shown in Figure 6.11-22. When operating group function, EPWMMODE0, EPWMMODE2 and EPWMMODE4 bits of CTL1 register must all set to 0 for independent mode or all set to 1 for complementary mode.



Figure 6.11-22 EPWM Group Function Waveform

#### 6.11.5.19 Synchronous Function

Synchronous function can only be enabled when complementary mode is enabled. Figure 6.11-24 is counter synchronous function block diagram. Every counter of EPWM pairs has a SYNC\_IN and a SYNC\_OUT signals. The SYNC\_IN signal for the first EPWM0 pair counter comes from EPWM0\_SYNC\_IN pin, and the others come from the SYNC\_OUT signal of the previous EPWM pair counter. The input signal from EPWM0\_SYNC\_IN pin will be filtered by a 3-bit noise filter as Figure 6.11-23. In addition, it can be inversed by setting the bit SINPINV (EPWM\_SYNC[23]) to realize the polarity setup for the input signal. The noise filter sampling clock can be selected by setting bits SFLTCSEL (EPWM\_SYNC[19:17]) to fit different noise properties. Moreover, by setting the bits SFLTCNT (EPWM\_SYNC[22:20]), user can define by how many sampling clock cycles a filter will recognize the effective edge of the SYNC\_IN signal. Configuring the SNFLTEN (EPWM\_SYNC[16]) will enable the noise filter function. By default, it is disabled.



Figure 6.11-23 EPWM SYNC\_IN Noise Filter Block Diagram

User can use SINSRCn (EPWM\_SYNC[13:8]) bits to select the synchronize source. When SINSRCn bits is set to 0, user can generate SYNC\_IN signal for the next counter's synchronization when EPWM0\_SYNC\_IN pin is high or setting SWSYNCn (EPWM\_SWSYNC[2:0]) to 1. Synchronizing source can also be selected as CNT = 0 or CNT = EPWM\_CMPDATm register (if being the up-down counter type, it will synchronize twice in a EPWM period) to trigger a sync event or to disable SYNC\_OUT signal.

When the PHSENn (EPWM\_SYNC[2:0]) is enabled and the synchronous source has a happening event, the counter will load a value from the PHS (EPWM\_PHSn\_m[15:0]) register. This method synchronizes counters to different phase in the same time. In the up-down counter type, user can set the value in PHSDIRn (EPWM\_SYNC[26:24]) to control the counter direction after synchronization. Although the Synchronous function can synchronize channels in phase, it can't work from the beginning of EPWM enable. To start EPWM and BPWM counters in the same time, user have to set the EPWM Synchronous Start Control Register (EPWM\_SSCTL[5:0]) to enable the channel counters which are planned to start counting together, and select the SSRC(EPWM\_SSCTL[9:8]) to choose the Synchronous Start source, followed by setting the EPWM Synchronous Start Trigger Register CNTSEN (EPWM\_SSTRG[0]).

For applications, please do not use Group and Synchronous function simultaneously because the Synchronous function will be inactive.



Figure 6.11-24 EPWM Counter Synchronous Function Block Diagram

Figure 6.11-25 is an example of the synchronous function in the up-down counter type. In the example, synchronizing source comes from the external EPWM SYNC\_IN signal. At the beginning, the output waveform of EPWM\_CH0, EPWM\_CH2 and EPWM\_CH4 are in the same phase. Then at Point A, the EPWM SYNC input signal comes as a sync event, resulting in phase shifts and counting direction changes for all of the counters. To realize the altered counter behaviors before the sync event coming, user has to setup the corresponding phase value in the PHS of(EPWM\_PHSn\_m[15:0]) as well as the counting direction in the PHSDIRn (EPWM\_SYNC[26:24]). In this case, one third of phase shifts are made. by setting the corresponding channel n's counter counting direction after synchronizing, as illustrated around the left side of Figure 6.11-25.



Figure 6.11-25 EPWM Synchronous Function with Synchronize source from SYNC\_IN Signal

#### 6.11.5.20 EPWM Output Control

After EPWM pulse generation, there are four to six steps to control the output of EPWM channels. In independent mode, there are Mask, Brake, Pin Polarity and Output Enable four steps as shown in Figure 6.11-26. In complementary mode, it needs two more steps to precede these four steps, Complementary channels and Dead-Time Insertion as shown in Figure 6.11-27.



Figure 6.11-26 EPWMx\_CH0 Output Control in Independent Mode



Figure 6.11-27 EPWMx\_CH0 and EPWMx\_CH1 Output Control in Complementary Mode

#### 6.11.5.21 Dead-Time Insertion

In the complementary application, the complement channels may drive the external devices like power switches. The dead-time generator inserts a low level period called “dead-time” between complementary outputs to drive these devices safely and to prevent system or devices from the burn-out damage. Hence the dead-time control is a crucial mechanism to the proper operation of the complementary system. By setting corresponding channel n DTEN (EPWM\_DTCTLn\_m[16]) bit to enable dead-time function and DTCNT (EPWM\_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{EPWM}_\text{DTCTLn}[11:0])+1) * \text{EPWMx\_CLK period}$$

Dead-time insertion clock source can be selected from prescaler output by setting DTCKSEL (EPWM\_DTCTLn\_m[24]) to 1. By default, clock source comes from EPWM\_CLK, which is prescaler input. Then the dead-time can be calculated from the following formula:

$$\begin{aligned} \text{Dead-time} &= (\text{DTCNT } (\text{EPWM}_\text{DTCTLn}[11:0])+1) * \\ &(\text{CLKPSC } (\text{EPWM}_\text{CLKPSCn}[11:0])+1) * \text{EPWMx\_CLK period} \end{aligned}$$

Please note that the EPWM\_DTCTLn\_m are write-protected registers.

Figure 6.11-28 indicates the dead-time insertion for one pair of EPWM signals.



Figure 6.11-28 Dead-Time Insertion

#### 6.11.5.22 EPWM Mask Output Function

Each of the EPWM channel output value can be manually overridden with the settings in the EPWM Mask Enable Control Register (EPWM\_MSKEN) and the EPWM Masked Data Register (EPWM\_MSK). With these settings, the EPWM channel outputs can be assigned to specified logic states independent of the duty cycle comparison units. The EPWM mask bits are useful when controlling various types of Electrically Commutated Motor (ECM) like a BLDC motor. The EPWM\_MSKEN register contains six bits, MSKENn(EPWM\_MSKEN[5:0]). If the MASKENn is set to active-high, the EPWM channel n output will be overridden. The EPWM\_MSK register contains six bits, MSKDATn(EPWM\_MSK[5:0]). The bit value of the MSKDATn determines the state value of the EPWM channel n output when the channel is overridden. Figure 6.11-29 shows an example of how EPWM mask control can be used for the override feature.



Figure 6.11-29 Illustration of Mask Control Waveform

#### 6.11.5.23 EPWM Brake

Each EPWM module has two external input brake control signals. User can select active brake pin source is from EPWM<sub>x</sub>\_BRAKEy pin by BKxSRC bits of 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 BRKxNFFEN bits of BNF register, and noise filter sampling clock can be selected by setting BRKxNFSEL bits of BNF register to fit different noise properties. Moreover, by setting the BRKxFCNT bits, user can define by how many sampling clock cycles a filter will recognize the effective edge of the brake signal.

In addition, it can be inversed by setting the BRKxPINV (x denotes input external pin 0 or 1) bits of BNF register to realize the polarity setup for the brake control signals. Set BRKxPINV bit to 0, brake

event will occurred when EPWMx\_BRAKEy(x=0,1, y=0,1) pin status is from low to high; set BRKxPINV to 1, brake event will occurred when EPWMx\_BRAKEy pin status is from high to low.



Figure 6.11-30 Brake Noise Filter Block Diagram

For Complementary mode, it is often necessary to set a safe output state to the complement output pairs once the brake event occurs.

Each complementary channel pair shares a EPWM brake function, as shown Figure 6.11-31. To control paired channels to output safety state, user can setup BRKAEVEN (EPWM\_BRKCTL0\_1[17:16]) for even channels and BRKAODD (EPWM\_BRKCTL0\_1[19:18]) for odd channels when the fault brake event happens. There are two brake detectors: Edge detector and Level detector. When the edge detector detects the brake signal and BRKEIENn\_m (EPWM\_INTEN1[2:0]) is enabled, the brake function generates BRK\_INT. This interrupt needs software to clear, and the BRKESTS\_n (EPWM\_INTSTS1[21:16]) brake state will keep until the next EPWM 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 BRKLIEEn\_m (EPWM\_INTEN1[10:8]) is also enabled, the brake function will generate BRK\_INT, but BRKLSTS\_n (EPWM\_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 EPWM waveform period when brake condition removed without clear interrupt.



Figure 6.11-31 Brake Block Diagram for EPWMx\_CH0 and EPWMx\_CH1 Pair

Figure 6.11-32 illustrates the edge detector waveform for EPWMx\_CH0 and EPWMx\_CH1 pair. In this case, the edge detect brake source has occurred twice for the brake events. When the event occurs, both of the BRKEIF0 and BRKEIF1 flags are set and BRKESTS0 and BRKESTS1 bits are also set to indicate brake state of EPWMx\_CH0 and EPWMx\_CH1. For the first occurring event, software writes 1 to clear the BRKEIF0 flag. After that, the BRKESTS0 bit is cleared by hardware at the next start of the EPWM period. At the same moment, the EPWMx\_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, EPWMx\_CH1 outputs normally at the next start of the EPWM period.

As a contrast to the edge detector example, Figure 6.11-33 illustrates the level detector waveform for EPWMx\_CH0 and EPWMx\_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 EPWM period no matter at what states the BRKLIF0 and BRKLIF1 flags are at that moment.



Figure 6.11-32 Edge Detector Waveform for EPWMx\_CH0 and EPWMx\_CH1 Pair



Figure 6.11-33 Level Detector Waveform for EPWMx\_CH0 and EPWMx\_CH1 Pair

The two kinds of detectors detect the same seven brake sources: two from external input signals, two from analog comparators(ACMP), one from EADC result monitor (EADCRM), one from system fail and

one from software triggered, that are shown in Figure 6.11-34. ACMP brake sources will be detected only when internal ACMP0\_O or ACMP1\_O signal from low to high.

Among the above described brake sources, the brake source coming from system fail can still be specified to several different system fail conditions. These conditions include clock fail, Brown-out detect, SRAM parity check error and Core lockup. Figure 6.11-35 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 EPWM brake.



Figure 6.11-34 Brake Source Block Diagram



Figure 6.11-35 Brake System Fail Block Diagram

#### 6.11.5.24 LEB Function

Leading edge blanking (LEB) function is used to blank the false trigger from brake source ACMP which may be caused by EPWM output transition. Set LEBEN (EPWM\_LEBCTL[0]) to enable this function. LEB source comes from EPWM\_CH0, EPWM\_CH2 and EPWM\_CH4, use SRCENn (EPWM\_LEBCTL[10:8]) as input source enable. LEB function blanking time is decided by LEBCNT (EPWM\_LEBCNT[8:0]), when LEB detected trigger edge, then blanking time will count from LEBCNT+1 to 0, the counter clock base is ECLK. If a new trigger event occurs, blanking counter will reset to LEBCNT and down count again. LEB trigger edge can be rising, falling or both rising and falling edge by setting TRGTYPE (EPWM\_LEBCTL[17:16]). Figure 6.11-36 shows that LEB will blanking leading edge caused by EPWM\_CH0 and EPWM\_CH4.



Figure 6.11-36 EPWM LEB Function Waveform

#### 6.11.5.25 Polarity Control

Each EPWM port, from EPWM\_CH0 to EPWM\_CH5, has an independent polarity control module to configure the polarity of the active state of the EPWM output. By default, the EPWM output is active high. This implies the EPWM OFF state is low and ON state is high. This definition is variable through setting the EPWM Negative Polarity Control Register (EPWM\_POLCTL), for each individual EPWM channel. Figure 6.11-37 shows the initial state before EPWM starting with different polarity settings.



**Note:** Dead-time insertion; It is only effective in complementary mode  
**Note:** PINVx: Negative Polarity control bits; It controls the EPWM output initial state and polarity, x denotes 0 or 1.

Figure 6.11-37 Initial State and Polarity Control with Rising Edge Dead-Time Insertion

#### 6.11.5.26 EPWM Interrupt Generator

There are three independent interrupts for each EPWM as shown in Figure 6.11-39.

The 1<sup>st</sup> EPWM interrupt (EPWM\_INT) comes from EPWM complementary pair events. The counter can generate the Zero point Interrupt Flag ZIFn (EPWM\_INTSTS0[5:0], n=0,1..5) and the Period point Interrupt Flag PIFn (EPWM\_INTSTS0[13:8], n=0,1..5). When EPWM channel n's counter equals to the comparator value stored in EPWM\_CMPDATn register, 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 (EPWM\_INTSTS0[21:16]) is set and if matching at the opposite direction, the Down Interrupt Flag CMPDIFn (EPWM\_INTSTS0[29:24]) is set. If the corresponding interrupt enable bits are set, the trigger events will generate interrupt signals.

EPWM\_INT can use the EPWM\_IFAn (n=0~5) register to accumulate the number of times that the interrupt flags have been triggered for each channel. By setting one of IFAEN (EPWM\_IFAN[31], n=0~5) bit to 1 to enable accumulator, EPWM\_INT will switch interrupt source from every event trigger interrupt to trigger interrupt once every accumulate times.

By setting the IFASEL (EPWM\_IFAn[29:28], n=0~5) bits, user can select one of the 4 interrupt sources to accumulate interrupt flag times for each channel, and the number of times interrupt flags will compare with IFACNT (EPWM\_IFAn[15:0], n=0~5) bits. When interrupt accumulator equals IFACNT then set IFAIFn (EPWM\_AINTSTS[n], n=0~5) bits as EPWM\_INT signal if user enable IFAIENn (EPWM\_AINTEN[n], n=0~5) bits. Accumulator interrupt of each channel can also be as request source of PDMA. Figure 6.11-38 is an example of channel 0 using EPWM\_IFA0 register to

output EPWM\_INT once every IFCNT0+1 times interrupt events occurred.



Figure 6.11-38 EPWMx\_CH0 Accumulate Interrupt Waveform

The 2<sup>nd</sup> interrupt is the capture interrupt (CAP\_INT). It shares the EPWM\_INT vector in NVIC. The CAP\_INT can be generated when the CAPRLIFn (EPWM\_CAPIF[5:0]) flag is triggered and the Capture Rising Interrupt Enable bit CAPRIENn (EPWM\_CAPIEN[5:0]) is set to 1. Or in the falling edge condition, the CAPFLIFn (EPWM\_CAPIF[13:8]) flag can be triggered when the Capture Falling Interrupt Enable bit CAPFIENn (EPWM\_CAPIEN[13:8]) is set to 1.

The last one is the brake interrupt (BRK\_INT). The details of the BRK\_INT is described in the EPWM Brake section.

Figure 6.11-39 demonstrates the architecture of the EPWM interrupts.



Figure 6.11-39 EPWMx\_CH0 and EPWMx\_CH1 Pair Interrupt Architecture Diagram

### 6.11.5.27 EPWM Trigger EADC/DAC Generator

EPWM can be one of the EADC conversion trigger source. Each EPWM pair channels share the same trigger source. Setting TRGSELn bit of EPWM\_EADCTS0 and EPWM\_EADCTS1 registers is to select the trigger sources, where TRGSELn bit is TRGSEL0, TRGSEL1, ..., and TRGSEL5, which are located in EPWM\_EADCTS0[3:0], EPWM\_EADCTS0[11:8], EPWM\_EADCTS0[19:16], EPWM\_EADCTS0[27:24], EPWM\_EADCTS1[3:0] and EPWM\_EADCTS1[11:8], respectively. Setting TRGENn bit of EPWM\_EADCTS0 and EPWM\_EADCTS1 registers is to enable the trigger output to EADC, where TRGENn bit is TRGEN0, TRGEN1, ..., TRGEN5, which are located in EPWM\_EADCTS0[7], EPWM\_EADCTS0[15], EPWM\_EADCTS0[23], EPWM\_EADCTS0[31], EPWM\_EADCTS1[7] and EPWM\_EADCTS1[15], respectively. The number n (n = 0,1,..,5) denotes EPWM channel number.

There are 16 EPWM events can be selected as the trigger source for one pair of channels which shown in Figure 6.11-40. Figure 6.11-41 is the trigger EADC timing waveform in the up-down counter type.



Figure 6.11-40 EPWMx\_CH0 and EPWMx\_CH1 Pair Trigger EADC Block Diagram



Figure 6.11-41 EPWM Trigger EADC in Up-Down Counter Type Timing Waveform

EPWM can also be used to trigger DAC conversion. Each EPWM pair channel (CH0 and CH1, CH2 and CH3, CH4 and CH5) generates a trigger signal. Using the EPWM Trigger DAC Enable Register (EPWM\_DACTRGEN) can decide at which points to trigger DAC. The timing of the EPWM triggering DAC is similar to those for triggering EADC. However, DAC triggering function does not include the triggering events from comparison with FTCMPDAT, that is, there are no trigger points the same as FTCMPDATU and FTCMPDATD which are shown in EADC triggering.



Figure 6.11-42 EPWM\_CH0 and EPWM\_CH1 Pair Trigger DAC Block Diagram

### 6.11.5.28 Capture Operation

The channels of the capture input and the EPWM output share the same pin and counter. The counter can operate in up or down counter type. The capture function will always latch the EPWM counter to the RCAPDATn (EPWM\_RCAPDATn[15:0]) bits or the FCAPDATn (EPWM\_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 EPWM\_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 (EPWM\_CAPIEN[5:0]) bit is for the rising edge and the CAPFIENn (EPWM\_CAPIEN[13:8]) bit is for the falling edge. When rising or falling latch occurs, the corresponding EPWM counter may be reloaded with the value of EPWM\_PERIODn register, depending on the setting of RCRLDENn or FCRLDENn bits (where RCRLDENn and FCRLDENn are located at EPWM\_CAPCTL[21:16] and EPWM\_CAPCTL[29:24], respectively). Note that the corresponding GPIO pins must be configured as the capture function by enable the CAPINENn (EPWM\_CAPINEN[5:0]) bits for the corresponding capture channel n. Figure 6.11-43 is the capture block diagram of channel 0.



Figure 6.11-43 EPWM\_CH0 Capture Block Diagram

Figure 6.11-44 illustrates the capture function timing. In this case, the capture counter is set as EPWM 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 EPWM\_FCAPDATn register. When detecting the rising edge, it latches the counter value to the EPWM\_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.11-44 also illustrates the timing example for the interrupt and interrupt flag generation. When

the rising edge at channel n is detected, the corresponding CRLIFn (EPWM\_CAPIF[5:0]) bit is set by hardware. Similarly, a falling edge detection at channel n causes the corresponding CFLIFn (EPWM\_CAPIF[13:8]) bit is set by hardware. CRLIFn and CFLIFn bits can be cleared by software by writing '1'. If the CRLIFn bit is set and the CAPRIENn bit is enabled, the capture function generates an interrupt. If the CFLIFn bit is set and the CAPFIENn bit is enabled, the interrupt also happens.

A condition which is not shown in this figure is: if the rising latch happens again when the CRLIFn bit is already set, the Over run status CRLIFOVn (EPWM\_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 (EPWM\_CAPSTS[13:8]).



Figure 6.11-44 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 RCRLDENn bits of PWM\_CAPCTL register to 1.

For the negative pulse case, the channel low pulse width is calculated as  $(EPWM\_PERIODn + 1 - EPWM\_RCAPDATn) / EPWM\_{COUNTER}\_{TIME}$ , where one EPWM counter time is  $(CLKPSC+1) * \frac{1}{FCLK}$ .

EPWMx\_CLK clock time. In Figure 6.11-44, the low pulse width is  $8+1-5 = 4$  EPWM counter time.

For the positive pulse case, the channel high pulse width is calculated as  $(EPWM\_PERIODn + 1 - EPWM\_FCAPDATn)$  EPWM counter time, where one EPWM counter time is  $(CLKPSC+1) * EPWMx_CLK$  clock time. In Figure 6.11-44, the high pulse width is  $8+1-7 = 2$  EPWM counter time.

#### 6.11.5.29 Capture PDMA Function

The EPWM module supports the PDMA transfer function when operating in the capture mode. When the corresponding PDMA enable bit CHEnn\_m (CHENO\_1 at EPWM\_PDMACTL[0], CHEN2\_3 at EPWM\_PDMACTL[8] and CHEN4\_5 at EPWM\_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 (EPWM\_PDMACAPn\_m[15:0], n, m denotes complement pair channels) register in the capture module and has sent the register value to the memory. By setting CAPMODn\_m (CAPMOD0\_1 at EPWM\_PDMACTL[2:1], CAPMOD2\_3 at EPWM\_PDMACTL[10:9] and CAPMOD4\_5 at EPWM\_PDMACTL[18:17]) bits, the PDMA can transfer the rising edge captured data or falling edge captured data or both of them to the memory. When using the PDMA to transfer both of the falling and rising edge data, remember to set CAPORDn\_m (CAPORD0\_1 at EPWM\_PDMACTL[3], CAPORD2\_3 at EPWM\_PDMACTL[11] and CAPORD4\_5 at EPWM\_PDMACTL[19]) bit to decide the order of the transferred data (falling edge captured is first or rising edge captured first). The complement pair channels share a PDMA channel. Therefore, a selection bit CHSELn\_m (CHSEL0\_1 (EPWM\_PDMACTL[4]), CHSEL2\_3 (EPWM\_PDMACTL[12]) and CHSEL4\_5 (EPWM\_PDMACTL[20])) bit is used to decide either channel n or channel m can be serviced by the PDMA channel.

Figure 6.11-45 is capture PDMA waveform. In this case, the CHSEL0\_1 (EPWM\_PDMACTL[4]) bit is set to 0. Hence the PDMA will service channel 0 for the capture data transfer. CAPMOD0\_1 (EPWM\_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 (EPWM\_PDMACTL[1]) bit is set to 1, so the rising edge data will be the first data to transfer and following is the falling edge data to transfer. As shown in Figure 6.11-45, the last assertions of the CAPRIFO CRLIFO and CAPFIFO CFLIFO signal have some overlap. The value of EPWM\_RCAPDATA0 register is 11 will be loaded to EPWM\_PDMACAP0\_1 register to wait for transfer but not the EPWM\_FCAPDATA0 value. The EPWM\_PDMACAP0\_1 register saves the data which will be transferred to the memory by PDMA. The HWDATA in this figure denotes the data which are being transferred by PDMA.



Figure 6.11-45 Capture PDMA Operation Waveform of Channel 0

### 6.11.5.30 Accumulator PDMA Function

The EPWM module supports the PDMA transfer function when accumulator interrupt happened. Figure 6.11-46 shows accumulator PDMA function architecture. When the corresponding PDMA enable bit APDMAENn (EPWM\_APDMACTL[n], n=0~5) is set, accumulator module will send a request to PDMA controller when accumulator interrupt has happened, meaning that IFAIFn (EPWM\_AINTSTS[n], n=0~5) is set 1. The PDMA controller will issue an acknowledge to accumulator after it has read memory data and send the data to the particular register (EPWM\_PERIOD, etc.). So, user can use this function to change accumulator interrupt frequency.



Figure 6.11-46 Accumulator PDMA Function Architecture

### 6.11.6 Register Map

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

| Register                  | Offset        | R/W | Description                                    | Reset Value |
|---------------------------|---------------|-----|------------------------------------------------|-------------|
| <b>EPWM Base Address:</b> |               |     |                                                |             |
| EPWM0_BA = 0x4005_8000    |               |     |                                                |             |
| EPWM1_BA = 0x4005_9000    |               |     |                                                |             |
| x=0,1                     |               |     |                                                |             |
| EPWM_CTL0<br>x=0,1        | EPWMx_BA+0x00 | R/W | EPWM Control Register 0                        | 0x0000_0000 |
| EPWM_CTL1<br>x=0,1        | EPWMx_BA+0x04 | R/W | EPWM Control Register 1                        | 0x0000_0000 |
| EPWM_SYNC<br>x=0,1        | EPWMx_BA+0x08 | R/W | EPWM Synchronization Register                  | 0x0000_0000 |
| EPWM_SWSYNC<br>x=0,1      | EPWMx_BA+0x0C | R/W | EPWM Software Control Synchronization Register | 0x0000_0000 |
| EPWM_CLKSRC<br>x=0,1      | EPWMx_BA+0x10 | R/W | EPWM Clock Source Register                     | 0x0000_0000 |
| EPWM_CLKPSC0_1<br>x=0,1   | EPWMx_BA+0x14 | R/W | EPWM Clock Prescale Register 0/1               | 0x0000_0000 |
| EPWM_CLKPSC2_3<br>x=0,1   | EPWMx_BA+0x18 | R/W | EPWM Clock Prescale Register 2/3               | 0x0000_0000 |
| EPWM_CLKPSC4_5<br>x=0,1   | EPWMx_BA+0x1C | R/W | EPWM Clock Prescale Register 4/5               | 0x0000_0000 |
| EPWM_CNTEN<br>x=0,1       | EPWMx_BA+0x20 | R/W | EPWM Counter Enable Register                   | 0x0000_0000 |
| EPWM_CNTCLR<br>x=0,1      | EPWMx_BA+0x24 | R/W | EPWM Clear Counter Register                    | 0x0000_0000 |
| EPWM_LOAD<br>x=0,1        | EPWMx_BA+0x28 | R/W | EPWM Load Register                             | 0x0000_0000 |
| EPWM_PERIOD0<br>x=0,1     | EPWMx_BA+0x30 | R/W | EPWM Period Register 0                         | 0x0000_0000 |
| EPWM_PERIOD1<br>x=0,1     | EPWMx_BA+0x34 | R/W | EPWM Period Register 1                         | 0x0000_0000 |
| EPWM_PERIOD2<br>x=0,1     | EPWMx_BA+0x38 | R/W | EPWM Period Register 2                         | 0x0000_0000 |
| EPWM_PERIOD3<br>x=0,1     | EPWMx_BA+0x3C | R/W | EPWM Period Register 3                         | 0x0000_0000 |
| EPWM_PERIOD4<br>x=0,1     | EPWMx_BA+0x40 | R/W | EPWM Period Register 4                         | 0x0000_0000 |
| EPWM_PERIOD5<br>x=0,1     | EPWMx_BA+0x44 | R/W | EPWM Period Register 5                         | 0x0000_0000 |

|                                |               |     |                                     |             |
|--------------------------------|---------------|-----|-------------------------------------|-------------|
| <b>EPWM_CMPDAT0<br/>x=0,1</b>  | EPWMx_BA+0x50 | R/W | EPWM Comparator Register 0          | 0x0000_0000 |
| <b>EPWM_CMPDAT1<br/>x=0,1</b>  | EPWMx_BA+0x54 | R/W | EPWM Comparator Register 1          | 0x0000_0000 |
| <b>EPWM_CMPDAT2<br/>x=0,1</b>  | EPWMx_BA+0x58 | R/W | EPWM Comparator Register 2          | 0x0000_0000 |
| <b>EPWM_CMPDAT3<br/>x=0,1</b>  | EPWMx_BA+0x5C | R/W | EPWM Comparator Register 3          | 0x0000_0000 |
| <b>EPWM_CMPDAT4<br/>x=0,1</b>  | EPWMx_BA+0x60 | R/W | EPWM Comparator Register 4          | 0x0000_0000 |
| <b>EPWM_CMPDAT5<br/>x=0,1</b>  | EPWMx_BA+0x64 | R/W | EPWM Comparator Register 5          | 0x0000_0000 |
| <b>EPWM_DTCTL0_1<br/>x=0,1</b> | EPWMx_BA+0x70 | R/W | EPWM Dead-Time Control Register 0/1 | 0x0000_0000 |
| <b>EPWM_DTCTL2_3<br/>x=0,1</b> | EPWMx_BA+0x74 | R/W | EPWM Dead-Time Control Register 2/3 | 0x0000_0000 |
| <b>EPWM_DTCTL4_5<br/>x=0,1</b> | EPWMx_BA+0x78 | R/W | EPWM Dead-Time Control Register 4/5 | 0x0000_0000 |
| <b>EPWM_PHS0_1<br/>x=0,1</b>   | EPWMx_BA+0x80 | R/W | EPWM Counter Phase Register 0/1     | 0x0000_0000 |
| <b>EPWM_PHS2_3<br/>x=0,1</b>   | EPWMx_BA+0x84 | R/W | EPWM Counter Phase Register 2/3     | 0x0000_0000 |
| <b>EPWM_PHS4_5<br/>x=0,1</b>   | EPWMx_BA+0x88 | R/W | EPWM Counter Phase Register 4/5     | 0x0000_0000 |
| <b>EPWM_CNT0<br/>x=0,1</b>     | EPWMx_BA+0x90 | R   | EPWM Counter Register 0             | 0x0000_0000 |
| <b>EPWM_CNT1<br/>x=0,1</b>     | EPWMx_BA+0x94 | R   | EPWM Counter Register 1             | 0x0000_0000 |
| <b>EPWM_CNT2<br/>x=0,1</b>     | EPWMx_BA+0x98 | R   | EPWM Counter Register 2             | 0x0000_0000 |
| <b>EPWM_CNT3<br/>x=0,1</b>     | EPWMx_BA+0x9C | R   | EPWM Counter Register 3             | 0x0000_0000 |
| <b>EPWM_CNT4<br/>x=0,1</b>     | EPWMx_BA+0xA0 | R   | EPWM Counter Register 4             | 0x0000_0000 |
| <b>EPWM_CNT5<br/>x=0,1</b>     | EPWMx_BA+0xA4 | R   | EPWM Counter Register 5             | 0x0000_0000 |
| <b>EPWM_WGCTL0<br/>x=0,1</b>   | EPWMx_BA+0xB0 | R/W | EPWM Generation Register 0          | 0x0000_0000 |
| <b>EPWM_WGCTL1<br/>x=0,1</b>   | EPWMx_BA+0xB4 | R/W | EPWM Generation Register 1          | 0x0000_0000 |
| <b>EPWM_MSKEN</b>              | EPWMx_BA+0xB8 | R/W | EPWM Mask Enable Register           | 0x0000_0000 |

|                                   |                |     |                                             |             |
|-----------------------------------|----------------|-----|---------------------------------------------|-------------|
| x=0,1                             |                |     |                                             |             |
| <b>EPWM_MSK</b><br>x=0,1          | EPWMx_BA+0xBC  | R/W | EPWM Mask Data Register                     | 0x0000_0000 |
| <b>EPWM_BNF</b><br>x=0,1          | EPWMx_BA+0xC0  | R/W | EPWM Brake Noise Filter Register            | 0x0000_0000 |
| <b>EPWM_FAILBRK</b><br>x=0,1      | EPWMx_BA+0xC4  | R/W | EPWM System Fail Brake Control Register     | 0x0000_0000 |
| <b>EPWM_BRKCTL0_1</b><br>x=0,1    | EPWMx_BA+0xC8  | R/W | EPWM Brake Edge Detect Control Register 0/1 | 0x0000_0000 |
| <b>EPWM_BRKCTL2_3</b><br>x=0,1    | EPWMx_BA+0xCC  | R/W | EPWM Brake Edge Detect Control Register 2/3 | 0x0000_0000 |
| <b>EPWM_BRKCTL4_5</b><br>x=0,1    | EPWMx_BA+0xD0  | R/W | EPWM Brake Edge Detect Control Register 4/5 | 0x0000_0000 |
| <b>EPWM_POLCTL</b><br>x=0,1       | EPWMx_BA+0xD4  | R/W | EPWM Pin Polar Inverse Register             | 0x0000_0000 |
| <b>EPWM_POEN</b><br>x=0,1         | EPWMx_BA+0xD8  | R/W | EPWM Output Enable Register                 | 0x0000_0000 |
| <b>EPWM_SWBRK</b><br>x=0,1        | EPWMx_BA+0xDC  | W   | EPWM Software Brake Control Register        | 0x0000_0000 |
| <b>EPWM_INTENO</b><br>x=0,1       | EPWMx_BA+0xE0  | R/W | EPWM Interrupt Enable Register 0            | 0x0000_0000 |
| <b>EPWM_INTEN1</b><br>x=0,1       | EPWMx_BA+0xE4  | R/W | EPWM Interrupt Enable Register 1            | 0x0000_0000 |
| <b>EPWM_INTSTS0</b><br>x=0,1      | EPWMx_BA+0xE8  | R/W | EPWM Interrupt Flag Register 0              | 0x0000_0000 |
| <b>EPWM_INTSTS1</b><br>x=0,1      | EPWMx_BA+0xEC  | R/W | EPWM Interrupt Flag Register 1              | 0x0000_0000 |
| <b>EPWM_DACTRGEN</b><br>x=0,1     | EPWMx_BA+0xF4  | R/W | EPWM Trigger DAC Enable Register            | 0x0000_0000 |
| <b>EPWM_EADCTS0</b><br>x=0,1      | EPWMx_BA+0xF8  | R/W | EPWM Trigger EADC Source Select Register 0  | 0x0000_0000 |
| <b>EPWM_EADCTS1</b><br>x=0,1      | EPWMx_BA+0xFC  | R/W | EPWM Trigger EADC Source Select Register 1  | 0x0000_0000 |
| <b>EPWM_FT CMPDAT0_1</b><br>x=0,1 | EPWMx_BA+0x100 | R/W | EPWM Free Trigger Compare Register 0/1      | 0x0000_0000 |
| <b>EPWM_FT CMPDAT2_3</b><br>x=0,1 | EPWMx_BA+0x104 | R/W | EPWM Free Trigger Compare Register 2/3      | 0x0000_0000 |
| <b>EPWM_FT CMPDAT4_5</b><br>x=0,1 | EPWMx_BA+0x108 | R/W | EPWM Free Trigger Compare Register 4/5      | 0x0000_0000 |

|                                 |                |     |                                             |             |
|---------------------------------|----------------|-----|---------------------------------------------|-------------|
| <b>EPWM_SSCTL<br/>x=0,1</b>     | EPWMx_BA+0x110 | R/W | EPWM Synchronous Start Control Register     | 0x0000_0000 |
| <b>EPWM_SSTRG<br/>x=0,1</b>     | EPWMx_BA+0x114 | W   | EPWM Synchronous Start Trigger Register     | 0x0000_0000 |
| <b>EPWM_LEBCTL<br/>x=0,1</b>    | EPWMx_BA+0x118 | R/W | EPWM Leading Edge Blanking Control Register | 0x0000_0000 |
| <b>EPWM_LEBCNT<br/>x=0,1</b>    | EPWMx_BA+0x11C | R/W | EPWM Leading Edge Blanking Counter Register | 0x0000_0000 |
| <b>EPWM_STATUS<br/>x=0,1</b>    | EPWMx_BA+0x120 | R/W | EPWM Status Register                        | 0x0000_0000 |
| <b>EPWM_IFA0<br/>x=0,1</b>      | EPWMx_BA+0x130 | R/W | EPWM Interrupt Flag Accumulator Register 0  | 0x0000_0000 |
| <b>EPWM_IFA1<br/>x=0,1</b>      | EPWMx_BA+0x134 | R/W | EPWM Interrupt Flag Accumulator Register 1  | 0x0000_0000 |
| <b>EPWM_IFA2<br/>x=0,1</b>      | EPWMx_BA+0x138 | R/W | EPWM Interrupt Flag Accumulator Register 2  | 0x0000_0000 |
| <b>EPWM_IFA3<br/>x=0,1</b>      | EPWMx_BA+0x13C | R/W | EPWM Interrupt Flag Accumulator Register 3  | 0x0000_0000 |
| <b>EPWM_IFA4<br/>x=0,1</b>      | EPWMx_BA+0x140 | R/W | EPWM Interrupt Flag Accumulator Register 4  | 0x0000_0000 |
| <b>EPWM_IFA5<br/>x=0,1</b>      | EPWMx_BA+0x144 | R/W | EPWM Interrupt Flag Accumulator Register 5  | 0x0000_0000 |
| <b>EPWM_AINTSTS<br/>x=0,1</b>   | EPWMx_BA+0x150 | R/W | EPWM Accumulator Interrupt Flag Register    | 0x0000_0000 |
| <b>EPWM_AINTEN<br/>x=0,1</b>    | EPWMx_BA+0x154 | R/W | EPWM Accumulator Interrupt Enable Register  | 0x0000_0000 |
| <b>EPWM_APDMACTL<br/>x=0,1</b>  | EPWMx_BA+0x158 | R/W | EPWM Accumulator PDMA Control Register      | 0x0000_0000 |
| <b>EPWM_CAPINEN<br/>x=0,1</b>   | EPWMx_BA+0x200 | R/W | EPWM Capture Input Enable Register          | 0x0000_0000 |
| <b>EPWM_CAPCTL<br/>x=0,1</b>    | EPWMx_BA+0x204 | R/W | EPWM Capture Control Register               | 0x0000_0000 |
| <b>EPWM_CAPSTS<br/>x=0,1</b>    | EPWMx_BA+0x208 | R   | EPWM Capture Status Register                | 0x0000_0000 |
| <b>EPWM_RCAPDATA0<br/>x=0,1</b> | EPWMx_BA+0x20C | R   | EPWM Rising Capture Data Register 0         | 0x0000_0000 |
| <b>EPWM_FCAPDATA0<br/>x=0,1</b> | EPWMx_BA+0x210 | R   | EPWM Falling Capture Data Register 0        | 0x0000_0000 |
| <b>EPWM_RCAPDATA1<br/>x=0,1</b> | EPWMx_BA+0x214 | R   | EPWM Rising Capture Data Register 1         | 0x0000_0000 |
| <b>EPWM_FCAPDATA1</b>           | EPWMx_BA+0x218 | R   | EPWM Falling Capture Data Register 1        | 0x0000_0000 |

|                                 |                |     |                                        |             |
|---------------------------------|----------------|-----|----------------------------------------|-------------|
| x=0,1                           |                |     |                                        |             |
| <b>EPWM_RCAPDAT2</b><br>x=0,1   | EPWMx_BA+0x21C | R   | EPWM Rising Capture Data Register 2    | 0x0000_0000 |
| <b>EPWM_FCAPDAT2</b><br>x=0,1   | EPWMx_BA+0x220 | R   | EPWM Falling Capture Data Register 2   | 0x0000_0000 |
| <b>EPWM_RCAPDAT3</b><br>x=0,1   | EPWMx_BA+0x224 | R   | EPWM Rising Capture Data Register 3    | 0x0000_0000 |
| <b>EPWM_FCAPDAT3</b><br>x=0,1   | EPWMx_BA+0x228 | R   | EPWM Falling Capture Data Register 3   | 0x0000_0000 |
| <b>EPWM_RCAPDAT4</b><br>x=0,1   | EPWMx_BA+0x22C | R   | EPWM Rising Capture Data Register 4    | 0x0000_0000 |
| <b>EPWM_FCAPDAT4</b><br>x=0,1   | EPWMx_BA+0x230 | R   | EPWM Falling Capture Data Register 4   | 0x0000_0000 |
| <b>EPWM_RCAPDAT5</b><br>x=0,1   | EPWMx_BA+0x234 | R   | EPWM Rising Capture Data Register 5    | 0x0000_0000 |
| <b>EPWM_FCAPDAT5</b><br>x=0,1   | EPWMx_BA+0x238 | R   | EPWM Falling Capture Data Register 5   | 0x0000_0000 |
| <b>EPWM_PDMACTL</b><br>x=0,1    | EPWMx_BA+0x23C | R/W | EPWM PDMA Control Register             | 0x0000_0000 |
| <b>EPWM_PDMACAP0_1</b><br>x=0,1 | EPWMx_BA+0x240 | R   | EPWM Capture Channel 01 PDMA Register  | 0x0000_0000 |
| <b>EPWM_PDMACAP2_3</b><br>x=0,1 | EPWMx_BA+0x244 | R   | EPWM Capture Channel 23 PDMA Register  | 0x0000_0000 |
| <b>EPWM_PDMACAP4_5</b><br>x=0,1 | EPWMx_BA+0x248 | R   | EPWM Capture Channel 45 PDMA Register  | 0x0000_0000 |
| <b>EPWM_CAPIEN</b><br>x=0,1     | EPWMx_BA+0x250 | R/W | EPWM Capture Interrupt Enable Register | 0x0000_0000 |
| <b>EPWM_CAPIF</b><br>x=0,1      | EPWMx_BA+0x254 | R/W | EPWM Capture Interrupt Flag Register   | 0x0000_0000 |
| <b>EPWM_PBUF0</b><br>x=0,1      | EPWMx_BA+0x304 | R   | EPWM PERIOD0 Buffer                    | 0x0000_0000 |
| <b>EPWM_PBUF1</b><br>x=0,1      | EPWMx_BA+0x308 | R   | EPWM PERIOD1 Buffer                    | 0x0000_0000 |
| <b>EPWM_PBUF2</b><br>x=0,1      | EPWMx_BA+0x30C | R   | EPWM PERIOD2 Buffer                    | 0x0000_0000 |
| <b>EPWM_PBUF3</b><br>x=0,1      | EPWMx_BA+0x310 | R   | EPWM PERIOD3 Buffer                    | 0x0000_0000 |
| <b>EPWM_PBUF4</b><br>x=0,1      | EPWMx_BA+0x314 | R   | EPWM PERIOD4 Buffer                    | 0x0000_0000 |
| <b>EPWM_PBUF5</b><br>x=0,1      | EPWMx_BA+0x318 | R   | EPWM PERIOD5 Buffer                    | 0x0000_0000 |

|                                 |                |     |                                  |             |
|---------------------------------|----------------|-----|----------------------------------|-------------|
| <b>EPWM_CMPBUF0<br/>x=0,1</b>   | EPWMx_BA+0x31C | R   | EPWM CMPDAT0 Buffer              | 0x0000_0000 |
| <b>EPWM_CMPBUF1<br/>x=0,1</b>   | EPWMx_BA+0x320 | R   | EPWM CMPDAT1 Buffer              | 0x0000_0000 |
| <b>EPWM_CMPBUF2<br/>x=0,1</b>   | EPWMx_BA+0x324 | R   | EPWM CMPDAT2 Buffer              | 0x0000_0000 |
| <b>EPWM_CMPBUF3<br/>x=0,1</b>   | EPWMx_BA+0x328 | R   | EPWM CMPDAT3 Buffer              | 0x0000_0000 |
| <b>EPWM_CMPBUF4<br/>x=0,1</b>   | EPWMx_BA+0x32C | R   | EPWM CMPDAT4 Buffer              | 0x0000_0000 |
| <b>EPWM_CMPBUF5<br/>x=0,1</b>   | EPWMx_BA+0x330 | R   | EPWM CMPDAT5 Buffer              | 0x0000_0000 |
| <b>EPWM_CPSBUF0_1<br/>x=0,1</b> | EPWMx_BA+0x334 | R   | EPWM CLKPSC0_1 Buffer            | 0x0000_0000 |
| <b>EPWM_CPSBUF2_3<br/>x=0,1</b> | EPWMx_BA+0x338 | R   | EPWM CLKPSC2_3 Buffer            | 0x0000_0000 |
| <b>EPWM_CPSBUF4_5<br/>x=0,1</b> | EPWMx_BA+0x33C | R   | EPWM CLKPSC4_5 Buffer            | 0x0000_0000 |
| <b>EPWM_FTCBUF0_1<br/>x=0,1</b> | EPWMx_BA+0x340 | R   | EPWM FTCMPDAT0_1 Buffer          | 0x0000_0000 |
| <b>EPWM_FTCBUF2_3<br/>x=0,1</b> | EPWMx_BA+0x344 | R   | EPWM FTCMPDAT2_3 Buffer          | 0x0000_0000 |
| <b>EPWM_FTCBUF4_5<br/>x=0,1</b> | EPWMx_BA+0x348 | R   | EPWM FTCMPDAT4_5 Buffer          | 0x0000_0000 |
| <b>EPWM_FTCI<br/>x=0,1</b>      | EPWMx_BA+0x34C | R/W | EPWM FTCMPDAT Indicator Register | 0x0000_0000 |

### 6.11.7 Register Description

#### EPWM Control Register 0 (EPWM\_CTL0)

| Register  | Offset        | R/W | Description             |  |  |  | Reset Value |
|-----------|---------------|-----|-------------------------|--|--|--|-------------|
| EPWM_CTL0 | EPWMx_BA+0x00 | R/W | EPWM Control Register 0 |  |  |  | 0x0000_0000 |

|           |         |          |          |          |          |          |          |
|-----------|---------|----------|----------|----------|----------|----------|----------|
| 31        | 30      | 29       | 28       | 27       | 26       | 25       | 24       |
| DBGTRIOFF | DBGHALT | Reserved |          |          |          | GROUPEN  |          |
| 23        | 22      | 21       | 20       | 19       | 18       | 17       | 16       |
| Reserved  |         | IMMLDEN5 | IMMLDEN4 | IMMLDEN3 | IMMLDEN2 | IMMLDEN1 | IMMLDEN0 |
| 15        | 14      | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved  |         | WINLDEN5 | WINLDEN4 | WINLDEN3 | WINLDEN2 | WINLDEN1 | WINLDEN0 |
| 7         | 6       | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved  |         | CTRLD5   | CTRLD4   | CTRLD3   | CTRLD2   | CTRLD1   | CTRLD0   |

| Bits               | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]               | <b>DBGTRIOFF</b><br><b>ICE Debug Mode Acknowledge Disable Bit (Write Protect)</b><br>0 = ICE debug mode acknowledgement effects EPWM output.<br>EPWM pin will be forced as tri-state while ICE debug mode acknowledged.<br>1 = ICE debug mode acknowledgement disabled.<br>EPWM pin will keep output no matter ICE debug mode acknowledged or not.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [30]               | <b>DBGHALT</b><br><b>ICE Debug Mode Counter Halt (Write Protect)</b><br>If counter halt is enabled, EPWM 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><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                  |
| [29:26]            | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   |
| [24]               | <b>GROUPEN</b><br><b>Group Function Enable Bit</b><br>0 = The output waveform of each EPWM channel are independent.<br>1 = Unify the EPWM_CH2 and EPWM_CH4 to output the same waveform as EPWM_CH0 and unify the EPWM_CH3 and EPWM_CH5 to output the same waveform as EPWM_CH1.                                                                                                                                                |
| [23:22]            | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   |
| [16+n]<br>n=0,1..5 | <b>IMMLDENn</b><br><b>Immediately Load Enable Bits</b><br>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><b>Note:</b> If IMMLDENn is enabled, WINLDENn and CTRLDn will be invalid.                        |
| [15:14]            | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   |

|                   |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8+n]<br>n=0,1..5 | <b>WINLDEN<sub>n</sub></b> | <b>Window Load Enable Bits</b><br>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 will load to PBUF at the end point of each period. CMPDAT will load to CMPBUF at the end point of each period when valid reload window is set. The valid reload window is set by software write 1 to EPWM_LOAD register and cleared by hardware after load success. |
| [7:6]             | <b>Reserved</b>            | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [n]<br>n=0,1..5   | <b>CTRLD<sub>n</sub></b>   | <b>Center Re-load</b><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.                                                                                                                                                                                                                                                                                                            |

**EPWM Control Register 1 (EPWM\_CTL1)**

| Register  | Offset        | R/W | Description             |  |  |  | Reset Value |
|-----------|---------------|-----|-------------------------|--|--|--|-------------|
| EPWM_CTL1 | EPWMx_BA+0x04 | R/W | EPWM Control Register 1 |  |  |  | 0x0000_0000 |

|          |    |          |          |          |          |          |          |
|----------|----|----------|----------|----------|----------|----------|----------|
| 31       | 30 | 29       | 28       | 27       | 26       | 25       | 24       |
| Reserved |    |          |          |          | OUTMODE4 | OUTMODE2 | OUTMODE0 |
| 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
| Reserved |    | CNTMODE5 | CNTMODE4 | CNTMODE3 | CNTMODE2 | CNTMODE1 | CNTMODE0 |
| 15       | 14 | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved |    |          |          | CNTTYPE5 |          | CNTTYPE4 |          |
| 7        | 6  | 5        | 4        | 3        | 2        | 1        | 0        |
| CNTTYPE3 |    | CNTTYPE2 |          | CNTTYPE1 |          | CNTTYPE0 |          |

| Bits                  | Description     |                                                                                                                                                                                                                                                                               |
|-----------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:27]               | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                     |
| [24+n/2]<br>n=0,2,4   | <b>OUTMODEn</b> | <p><b>EPWM Output Mode</b></p> <p>Each bit n controls the output mode of corresponding EPWM channel n.</p> <p>0 = EPWM independent mode.<br/>1 = EPWM complementary mode.</p> <p><b>Note:</b> When operating in group function, these bits must all set to the same mode.</p> |
| [23:22]               | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                     |
| [16+n]<br>n=0,1..5    | <b>CNTMODEn</b> | <p><b>EPWM Counter Mode</b></p> <p>0 = Auto-reload mode.<br/>1 = One-shot mode.</p>                                                                                                                                                                                           |
| [15:12]               | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                     |
| [2n+1:2n]<br>n=0,1..5 | <b>CNTTYPEn</b> | <p><b>EPWM Counter Behavior Type</b></p> <p>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.</p>                                                                     |

**EPWM Synchronization Register (EPWM\_SYNC)**

| Register  | Offset        | R/W | Description                   |  |  |  | Reset Value |
|-----------|---------------|-----|-------------------------------|--|--|--|-------------|
| EPWM_SYNC | EPWMx_BA+0x08 | R/W | EPWM Synchronization Register |  |  |  | 0x0000_0000 |

|          |         |         |    |          |         |         |         |
|----------|---------|---------|----|----------|---------|---------|---------|
| 31       | 30      | 29      | 28 | 27       | 26      | 25      | 24      |
| Reserved |         |         |    |          | PHSDIR4 | PHSDIR2 | PHSDIR0 |
| 23       | 22      | 21      | 20 | 19       | 18      | 17      | 16      |
| SINPINV  | SFLTCNT |         |    | SFLTCSEL |         |         | SNFLTEN |
| 15       | 14      | 13      | 12 | 11       | 10      | 9       | 8       |
| Reserved |         | SINSRC4 |    | SINSRC2  |         | SINSRC0 |         |
| 7        | 6       | 5       | 4  | 3        | 2       | 1       | 0       |
| Reserved |         |         |    |          | PHSEN4  | PHSEN2  | PHSEN0  |

| Bits                 | Description     |                                                                                                                                                                                                                                                                                                                     |
|----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:27]              | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                           |
| [24+n/2]<br>n=0,2,4  | <b>PHSDIRn</b>  | <b>EPWM Phase Direction Control</b><br>0 = Control EPWM counter count decrement after synchronizing.<br>1 = Control EPWM counter count increment after synchronizing.                                                                                                                                               |
| [23]                 | <b>SINPINV</b>  | <b>SYNC Input Pin Inverse</b><br>0 = The state of pin SYNC is passed to the negative edge detector.<br>1 = The inversed state of pin SYNC is passed to the negative edge detector.                                                                                                                                  |
| [22:20]              | <b>SFLTCNT</b>  | <b>SYNC Edge Detector Filter Count</b><br>The register bits control the counter number of edge detector.                                                                                                                                                                                                            |
| [19:17]              | <b>SFLTCSEL</b> | <b>SYNC Edge Detector Filter Clock Selection</b><br>000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.<br>011 = Filter clock = HCLK/8.<br>100 = Filter clock = HCLK/16.<br>101 = Filter clock = HCLK/32.<br>110 = Filter clock = HCLK/64.<br>111 = Filter clock = HCLK/128. |
| [16]                 | <b>SNFLTEN</b>  | <b>EPWM0_SYNC_IN Noise Filter Enable Bits</b><br>0 = Noise filter of input pin EPWM0_SYNC_IN Disabled.<br>1 = Noise filter of input pin EPWM0_SYNC_IN Enabled.                                                                                                                                                      |
| [15:14]              | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                           |
| [9+n:8+n]<br>n=0,2,4 | <b>SINSRCn</b>  | <b>EPWM0_SYNC_IN Source Selection</b><br>00 = Synchronize source from SYNC_IN or SWSYNC.<br>01 = Counter equal to 0.                                                                                                                                                                                                |

|                  |                 |                                                                                                                            |
|------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------|
|                  |                 | 10 = Counter equal to EPWM_CMPDATm, m denotes 1, 3, 5.<br>11 = SYNC_OUT will not be generated.                             |
| [7:3]            | <b>Reserved</b> | Reserved.                                                                                                                  |
| [n/2]<br>n=0,2,4 | <b>PHSENn</b>   | <b>SYNC Phase Enable Bits</b><br>0 = EPWM counter disable to load PHS value.<br>1 = EPWM counter enable to load PHS value. |

**EPWM Software Control Synchronization Register (EPWM\_SWSYNC)**

| Register    | Offset        | R/W | Description                                    |  |  |  |  | Reset Value |
|-------------|---------------|-----|------------------------------------------------|--|--|--|--|-------------|
| EPWM_SWSYNC | EPWMx_BA+0x0C | R/W | EPWM Software Control Synchronization 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 |    |    |    |    | SWSYNC4 | SWSYNC2 | SWSYNC0 |

| Bits             | Description |                                                                                                                                   |
|------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| [31:3]           | Reserved    | Reserved.                                                                                                                         |
| [n/2]<br>n=0,2,4 | SWSYNCn     | <b>Software SYNC Function</b><br>When SINSRCn (EPWM_SYNC[13:8]) is selected to 0, SYNC_OUT source comes from SYNC_IN or this bit. |

**EPWM Clock Source Register (EPWM\_CLKSRC)**

| Register    | Offset        | R/W | Description                |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------|--|--|--|-------------|
| EPWM_CLKSRC | EPWMx_BA+0x10 | R/W | EPWM Clock Source Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                   |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | Reserved    | Reserved.                                                                                                                                                                                                         |
| [18:16] | ECLKSRC4    | <b>EPWM_CH45 External Clock Source Select</b><br>000 = EPWMx_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. |
| [15:11] | Reserved    | Reserved.                                                                                                                                                                                                         |
| [10:8]  | ECLKSRC2    | <b>EPWM_CH23 External Clock Source Select</b><br>000 = EPWMx_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. |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                         |
| [2:0]   | ECLKSRC0    | <b>EPWM_CH01 External Clock Source Select</b><br>000 = EPWMx_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. |

**EPWM Clock Prescale Register 0\_1, 2\_3, 4\_5 (EPWM\_CLKPSC0\_1, 2\_3, 4\_5)**

| Register       | Offset        | R/W | Description                      |  |  |  | Reset Value |
|----------------|---------------|-----|----------------------------------|--|--|--|-------------|
| EPWM_CLKPSC0_1 | EPWMx_BA+0x14 | R/W | EPWM Clock Prescale Register 0/1 |  |  |  | 0x0000_0000 |
| EPWM_CLKPSC2_3 | EPWMx_BA+0x18 | R/W | EPWM Clock Prescale Register 2/3 |  |  |  | 0x0000_0000 |
| EPWM_CLKPSC4_5 | EPWMx_BA+0x1C | R/W | EPWM Clock Prescale Register 4/5 |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                    |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                          |
| [11:0]  | CLKPSC      | EPWM Counter Clock Prescale<br>The clock of EPWM counter is decided by clock prescaler. Each EPWM pair share one EPWM counter clock prescaler. The clock of EPWM counter is divided by (CLKPSC+1). |

**EPWM Counter Enable Register (EPWM\_CNTEN)**

| Register   | Offset        | R/W | Description                  | Reset Value |
|------------|---------------|-----|------------------------------|-------------|
| EPWM_CNTEN | EPWMx_BA+0x20 | R/W | EPWM Counter Enable Register | 0x0000_0000 |

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

| Bits            | Description |                                                                                                                                              |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                    |
| [n]<br>n=0,1..5 | CNTENn      | <b>EPWM Counter Enable Bits</b><br>0 = EPWM Counter and clock prescaler stop running.<br>1 = EPWM Counter and clock prescaler start running. |

**EPWM Clear Counter Register (EPWM\_CNTCLR)**

| Register    | Offset        | R/W | Description                 | Reset Value |
|-------------|---------------|-----|-----------------------------|-------------|
| EPWM_CNTCLR | EPWMx_BA+0x24 | R/W | EPWM Clear Counter Register | 0x0000_0000 |

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

| Bits            | Description |                                                                                                                                                                                                                      |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                                                            |
| [n]<br>n=0,1..5 | CNTCLRn     | <p><b>Clear EPWM Counter Control Bit</b></p> <p>It is automatically cleared by hardware. Each bit n controls the corresponding EPWM channel n.</p> <p>0 = No effect.<br/>1 = Clear 16-bit EPWM counter to 0000H.</p> |

**EPWM Load Register (EPWM\_LOAD)**

| Register  | Offset        | R/W | Description        |  |  |  | Reset Value |
|-----------|---------------|-----|--------------------|--|--|--|-------------|
| EPWM_LOAD | EPWMx_BA+0x28 | R/W | EPWM Load Register |  |  |  | 0x0000_0000 |

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

| Bits            | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [n]<br>n=0,1..5 | LOADn       | <p><b>Re-load EPWM Comparator Register (CMPDAT) Control Bit</b></p> <p>This bit is software write, hardware clear when current EPWM period end.</p> <p>Write Operation:</p> <p>0 = No effect.<br/>1 = Set load window of window loading mode.</p> <p>Read Operation:</p> <p>0 = No load window is set.<br/>1 = Load window is set.</p> <p><b>Note:</b> This bit only use in window loading mode, WINLDENn(EPWM_CTRL0[13:8]) = 1.</p> |

**EPWM Period Register 0~5 (EPWM\_PERIOD0~5)**

| Register     | Offset        | R/W | Description            | Reset Value |
|--------------|---------------|-----|------------------------|-------------|
| EPWM_PERIOD0 | EPWMx_BA+0x30 | R/W | EPWM Period Register 0 | 0x0000_0000 |
| EPWM_PERIOD1 | EPWMx_BA+0x34 | R/W | EPWM Period Register 1 | 0x0000_0000 |
| EPWM_PERIOD2 | EPWMx_BA+0x38 | R/W | EPWM Period Register 2 | 0x0000_0000 |
| EPWM_PERIOD3 | EPWMx_BA+0x3C | R/W | EPWM Period Register 3 | 0x0000_0000 |
| EPWM_PERIOD4 | EPWMx_BA+0x40 | R/W | EPWM Period Register 4 | 0x0000_0000 |
| EPWM_PERIOD5 | EPWMx_BA+0x44 | R/W | EPWM Period Register 5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [15:0]  | PERIOD      | <p><b>EPWM Period Register</b></p> <p>Up-Count mode: In this mode, EPWM counter counts from 0 to PERIOD, and restarts from 0.</p> <p>Down-Count mode: In this mode, EPWM counter counts from PERIOD to 0, and restarts from PERIOD.</p> <p>EPWM period time = (PERIOD+1) * EPWM_CLK period.</p> <p>Up-Down-Count mode: In this mode, EPWM counter counts from 0 to PERIOD, then decrements to 0 and repeats again.</p> <p>EPWM period time = 2 * PERIOD * EPWM_CLK period.</p> |

**EPWM Comparator Register 0~5 (EPWM\_CMPDAT0~5)**

| Register     | Offset        | R/W | Description                | Reset Value |
|--------------|---------------|-----|----------------------------|-------------|
| EPWM_CMPDAT0 | EPWMx_BA+0x50 | R/W | EPWM Comparator Register 0 | 0x0000_0000 |
| EPWM_CMPDAT1 | EPWMx_BA+0x54 | R/W | EPWM Comparator Register 1 | 0x0000_0000 |
| EPWM_CMPDAT2 | EPWMx_BA+0x58 | R/W | EPWM Comparator Register 2 | 0x0000_0000 |
| EPWM_CMPDAT3 | EPWMx_BA+0x5C | R/W | EPWM Comparator Register 3 | 0x0000_0000 |
| EPWM_CMPDAT4 | EPWMx_BA+0x60 | R/W | EPWM Comparator Register 4 | 0x0000_0000 |
| EPWM_CMPDAT5 | EPWMx_BA+0x64 | R/W | EPWM Comparator Register 5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [15:0]  | CMP         | <p><b>EPWM Comparator Register</b></p> <p>CMP is used to compare with CNTR to generate EPWM waveform, interrupt and trigger EADC/DAC.</p> <p>In independent mode, CMPDAT0~5 denote as 6 independent EPWM_CH0~5 compared point.</p> <p>In complementary mode, CMPDAT0, 2, 4 denote as first compared point, and CMPDAT1, 3, 5 denote as second compared point for the corresponding 3 complementary pairs EPWM_CH0 and EPWM_CH1, EPWM_CH2 and EPWM_CH3, EPWM_CH4 and EPWM_CH5.</p> |

**EPWM Dead-time Control Register 0\_1, 2\_3, 4\_5 (EPWM\_DTCTL0\_1, 2\_3, 4\_5)**

| Register      | Offset        | R/W | Description                         |  |  |  | Reset Value |
|---------------|---------------|-----|-------------------------------------|--|--|--|-------------|
| EPWM_DTCTL0_1 | EPWMx_BA+0x70 | R/W | EPWM Dead-Time Control Register 0/1 |  |  |  | 0x0000_0000 |
| EPWM_DTCTL2_3 | EPWMx_BA+0x74 | R/W | EPWM Dead-Time Control Register 2/3 |  |  |  | 0x0000_0000 |
| EPWM_DTCTL4_5 | EPWMx_BA+0x78 | R/W | EPWM Dead-Time Control Register 4/5 |  |  |  | 0x0000_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 |    |    |    | DTCNT |    |    |         |
| 7        | 6  | 5  | 4  | 3     | 2  | 1  | 0       |
| DTCNT    |    |    |    |       |    |    |         |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [24]    | DTCKSEL     | <b>Dead-time Clock Select (Write Protect)</b><br>0 = Dead-time clock source from EPWM_CLK.<br>1 = Dead-time clock source from prescaler output.<br><b>Note:</b> This bit is write protected. Refer to REGWRPROT register.                                                                                                                                                                                                                                                                                   |
| [23:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [16]    | DTEN        | <b>Enable Dead-time Insertion for EPWM Pair (EPWM_CH0, EPWM_CH1) (EPWM_CH2, EPWM_CH3) (EPWM_CH4, EPWM_CH5) (Write Protect)</b><br>Dead-time insertion is only active when this pair of complementary EPWM is enabled. If dead-time insertion is inactive, the outputs of pin pair are complementary without any delay.<br>0 = Dead-time insertion Disabled on the pin pair.<br>1 = Dead-time insertion Enabled on the pin pair.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [11:0]  | DTCNT       | <b>Dead-time Counter (Write Protect)</b><br>The dead-time can be calculated from the following formula:<br>DTCKSEL=0: Dead-time = (DTCNT[11:0]+1) * EPWM_CLK period.<br>DTCKSEL=1: Dead-time = (DTCNT[11:0]+1) * EPWM_CLK period * (CLKPSC+1).<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                  |

**EPWM Counter Phase Register 0\_1, 2\_3, 4\_5 (EPWM\_PHS0\_1, 2\_3, 4\_5)**

| Register    | Offset        | R/W | Description                     | Reset Value |
|-------------|---------------|-----|---------------------------------|-------------|
| EPWM_PHS0_1 | EPWMx_BA+0x80 | R/W | EPWM Counter Phase Register 0/1 | 0x0000_0000 |
| EPWM_PHS2_3 | EPWMx_BA+0x84 | R/W | EPWM Counter Phase Register 2/3 | 0x0000_0000 |
| EPWM_PHS4_5 | EPWMx_BA+0x88 | R/W | EPWM Counter Phase Register 4/5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                       |
| [15:0]  | PHS         | <b>EPWM Synchronous Start Phase Bits</b><br>PHS determines the EPWM synchronous start phase value. These bits only use in synchronous function. |

**EPWM Counter Register 0~5 (EPWM\_CNT0~5)**

| Register         | Offset        | R/W | Description             | Reset Value |
|------------------|---------------|-----|-------------------------|-------------|
| <b>EPWM_CNT0</b> | EPWMx_BA+0x90 | R   | EPWM Counter Register 0 | 0x0000_0000 |
| <b>EPWM_CNT1</b> | EPWMx_BA+0x94 | R   | EPWM Counter Register 1 | 0x0000_0000 |
| <b>EPWM_CNT2</b> | EPWMx_BA+0x98 | R   | EPWM Counter Register 2 | 0x0000_0000 |
| <b>EPWM_CNT3</b> | EPWMx_BA+0x9C | R   | EPWM Counter Register 3 | 0x0000_0000 |
| <b>EPWM_CNT4</b> | EPWMx_BA+0xA0 | R   | EPWM Counter Register 4 | 0x0000_0000 |
| <b>EPWM_CNT5</b> | EPWMx_BA+0xA4 | R   | EPWM Counter Register 5 | 0x0000_0000 |



| Bits    | Description     |                                                                                                                    |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------|
| [31:17] | <b>Reserved</b> | Reserved.                                                                                                          |
| [16]    | <b>DIRF</b>     | <b>EPWM Direction Indicator Flag (Read Only)</b><br>0 = Counter is counting down.<br>1 = Counter is counting up.   |
| [15:0]  | <b>CNT</b>      | <b>EPWM Data Register (Read Only)</b><br>User can monitor CNTR to know the current value in 16-bit period counter. |

**EPWM Generation Register 0 (EPWM\_WGCTL0)**

| Register    | Offset        | R/W | Description                |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------|--|--|--|-------------|
| EPWM_WGCTL0 | EPWMx_BA+0xB0 | R/W | EPWM 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 |          | PRDPCTL0 |    |
| 15       | 14 | 13       | 12 | 11       | 10       | 9        | 8  |
| Reserved |    |          |    | ZPCTL5   | ZPCTL4   |          |    |
| 7        | 6  | 5        | 4  | 3        | 2        | 1        | 0  |
| ZPCTL3   |    | ZPCTL2   |    | ZPCTL1   | ZPCTL0   |          |    |

| Bits                      | Description          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28]                   | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [17+2n:16+2n]<br>n=0,1..5 | PRDPCTL <sub>n</sub> | <p><b>EPWM Period (Center) Point Control</b></p> <p>00 = Do nothing.<br/>           01 = EPWM period (center) point output Low.<br/>           10 = EPWM period (center) point output High.<br/>           11 = EPWM period (center) point output Toggle.</p> <p><b>Note1:</b> EPWM can control output level when EPWM counter counts to (PERIOD<sub>n</sub>+1).</p> <p><b>Note2:</b> This bit is center point control when EPWM counter operating in up-down counter type.</p> |
| [15:12]                   | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [1+2n:2n]<br>n=0,1..5     | ZPCTL <sub>n</sub>   | <p><b>EPWM Zero Point Control</b></p> <p>00 = Do nothing.<br/>           01 = EPWM zero point output Low.<br/>           10 = EPWM zero point output High.<br/>           11 = EPWM zero point output Toggle.</p> <p><b>Note:</b> EPWM can control output level when EPWM counter counts to 0.</p>                                                                                                                                                                              |

**EPWM Generation Register 1 (EPWM\_WGCTL1)**

| Register    | Offset        | R/W | Description                |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------|--|--|--|-------------|
| EPWM_WGCTL1 | EPWMx_BA+0xB4 | R/W | EPWM 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 | CMPDCTL0 |    |    |
| 15       | 14 | 13       | 12 | 11       | 10       | 9  | 8  |
| Reserved |    |          |    | CMPUCTL5 | CMPUCTL4 |    |    |
| 7        | 6  | 5        | 4  | 3        | 2        | 1  | 0  |
| CMPUCTL3 |    | CMPUCTL2 |    | CMPUCTL1 | CMPUCTL0 |    |    |

| Bits                      | Description          |                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28]                   | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [17+2n:16+2n]<br>n=0,1..5 | CMPDCTL <sub>n</sub> | <p><b>EPWM Compare Down Point Control</b></p> <p>00 = Do nothing.<br/>           01 = EPWM compare down point output Low.<br/>           10 = EPWM compare down point output High.<br/>           11 = EPWM compare down point output Toggle.</p> <p>EPWM can control output level when EPWM counter counts down to CMPDAT.</p> <p><b>Note:</b> In complementary mode, CMPDCTL1, 3, 5 is used as another CMPDCTL for channel 0, 2, 4.</p>      |
| [15:12]                   | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [1+2n:2n]<br>n=0,1..5     | CMPUCTL <sub>n</sub> | <p><b>EPWM Compare Up Point Control</b></p> <p>00 = Do nothing.<br/>           01 = EPWM compare up point output Low.<br/>           10 = EPWM compare up point output High.<br/>           11 = EPWM compare up point output Toggle.</p> <p><b>Note1:</b> EPWM can control output level when EPWM counter counts up to CMPDAT.</p> <p><b>Note2:</b> In complementary mode, CMPUCTL1, 3, 5 is used as another CMPUCTL for channel 0, 2, 4.</p> |

**EPWM Mask Enable Register (EPWM\_MSKEN)**

| Register    | Offset        | R/W | Description               |  |  |  |  | Reset Value |
|-------------|---------------|-----|---------------------------|--|--|--|--|-------------|
| EPWM_MSKE_N | EPWMx_BA+0xB8 | R/W | EPWM 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.                                                                                                                                                                                                                                                                                           |
| [n]<br>n=0,1..5 | MSKENn      | <p><b>EPWM Mask Enable Bits</b></p> <p>The EPWM output signal will be masked when this bit is enabled. The corresponding EPWM channel n will output MSKDATn (EPWM_MSK[5:0]) data.</p> <p>0 = EPWM output signal is non-masked.</p> <p>1 = EPWM output signal is masked and output MSKDATn data.</p> |

**EPWM Mask DATA Register (EPWM\_MSK)**

| Register | Offset        | R/W | Description             |  |  |  | Reset Value |
|----------|---------------|-----|-------------------------|--|--|--|-------------|
| EPWM_MSK | EPWMx_BA+0xBC | R/W | EPWM Mask Data Register |  |  |  | 0x0000_0000 |

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

| Bits            | Description |                                                                                                                                                                                                                                        |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                                                                              |
| [n]<br>n=0,1..5 | MSKDATn     | <p><b>EPWM Mask Data Bit</b></p> <p>This data bit control the state of EPWMn output pin, if corresponding mask function is enabled.</p> <p>0 = Output logic low to EPWM channel n.</p> <p>1 = Output logic high to EPWM channel n.</p> |

**EPWM Brake Noise Filter Register (EPWM\_BNF)**

| Register | Offset        | R/W | Description                      |  |  |  |  | Reset Value |
|----------|---------------|-----|----------------------------------|--|--|--|--|-------------|
| EPWM_BNF | EPWMx_BA+0xC0 | R/W | EPWM Brake Noise Filter Register |  |  |  |  | 0x0000_0000 |

|          |          |    |    |           |    |    |          |
|----------|----------|----|----|-----------|----|----|----------|
| 31       | 30       | 29 | 28 | 27        | 26 | 25 | 24       |
| Reserved |          |    |    |           |    |    | BK1SRC   |
| 23       | 22       | 21 | 20 | 19        | 18 | 17 | 16       |
| Reserved |          |    |    |           |    |    | BK0SRC   |
| 15       | 14       | 13 | 12 | 11        | 10 | 9  | 8        |
| BRK1PINV | BRK1FCNT |    |    | BRK1NFSEL |    |    | BRK1NFEN |
| 7        | 6        | 5  | 4  | 3         | 2  | 1  | 0        |
| BRK0PINV | BRK0FCNT |    |    | BRK0NFSEL |    |    | BRK0NFEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |
| [24]    | BK1SRC      | <b>Brake 1 Pin Source Select</b><br>For EPWM0 setting:<br>0 = Brake 1 pin source come from EPWM0_BRAKE1.<br>1 = Brake 1 pin source come from EPWM1_BRAKE1.<br>For EPWM1 setting:<br>0 = Brake 1 pin source come from EPWM1_BRAKE1.<br>1 = Brake 1 pin source come from EPWM0_BRAKE1. |
| [23:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |
| [16]    | BK0SRC      | <b>Brake 0 Pin Source Select</b><br>For EPWM0 setting:<br>0 = Brake 0 pin source come from EPWM0_BRAKE0.<br>1 = Brake 0 pin source come from EPWM1_BRAKE0.<br>For EPWM1 setting:<br>0 = Brake 0 pin source come from EPWM1_BRAKE0.<br>1 = Brake 0 pin source come from EPWM0_BRAKE0. |
| [15]    | BRK1PINV    | <b>Brake 1 Pin Inverse</b><br>0 = The state of pin EPWMx_BRAKE1 is passed to the negative edge detector.<br>1 = The inversed state of pin EPWMx_BRAKE1 is passed to the negative edge detector.                                                                                      |
| [14:12] | BRK1FCNT    | <b>Brake 1 Edge Detector Filter Count</b><br>The register bits control the Brake1 filter counter to count from 0 to BRK1FCNT.                                                                                                                                                        |
| [11:9]  | BRK1NFSEL   | <b>Brake 1 Edge Detector Filter Clock Selection</b><br>000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.                                                                                                                                    |

|       |                  |                                                                                                                                                                                                                                                                                                                        |
|-------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                  | 011 = Filter clock = HCLK/8.<br>100 = Filter clock = HCLK/16.<br>101 = Filter clock = HCLK/32.<br>110 = Filter clock = HCLK/64.<br>111 = Filter clock = HCLK/128.                                                                                                                                                      |
| [8]   | <b>BRK1NFEN</b>  | <b>EPWM Brake 1 Noise Filter Enable Bit</b><br>0 = Noise filter of EPWM Brake 1 Disabled.<br>1 = Noise filter of EPWM Brake 1 Enabled.                                                                                                                                                                                 |
| [7]   | <b>BRK0PINV</b>  | <b>Brake 0 Pin Inverse</b><br>0 = The state of pin EPWMx_BRAKE0 is passed to the negative edge detector.<br>1 = The inversed state of pin EPWMx_BRAKE10 is passed to the negative edge detector.                                                                                                                       |
| [6:4] | <b>BRK0FCNT</b>  | <b>Brake 0 Edge Detector Filter Count</b><br>The register bits control the Brake0 filter counter to count from 0 to BRK1FCNT.                                                                                                                                                                                          |
| [3:1] | <b>BRK0NFSEL</b> | <b>Brake 0 Edge Detector Filter Clock Selection</b><br>000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.<br>011 = Filter clock = HCLK/8.<br>100 = Filter clock = HCLK/16.<br>101 = Filter clock = HCLK/32.<br>110 = Filter clock = HCLK/64.<br>111 = Filter clock = HCLK/128. |
| [0]   | <b>BRK0NFEN</b>  | <b>EPWM Brake 0 Noise Filter Enable Bit</b><br>0 = Noise filter of EPWM Brake 0 Disabled.<br>1 = Noise filter of EPWM Brake 0 Enabled.                                                                                                                                                                                 |

**EPWM System Fail Brake Control Register (EPWM\_FAILBRK)**

| Register     | Offset        | R/W | Description                             | Reset Value |
|--------------|---------------|-----|-----------------------------------------|-------------|
| EPWM_FAILBRK | EPWMx_BA+0xC4 | R/W | EPWM System Fail Brake Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                    |
| [3]    | CORBRKEN    | <b>Core Lockup Detection Trigger EPWM Brake Function 0 Enable Bit</b><br>0 = Brake Function triggered by Core lockup detection Disabled.<br>1 = Brake Function triggered by Core lockup detection Enabled.                   |
| [2]    | RAMBRKEN    | <b>SRAM Parity Error Detection Trigger EPWM Brake Function 0 Enable Bit</b><br>0 = Brake Function triggered by SRAM parity error detection Disabled.<br>1 = Brake Function triggered by SRAM parity error detection Enabled. |
| [1]    | BODBRKEN    | <b>Brown-out Detection Trigger EPWM Brake Function 0 Enable Bit</b><br>0 = Brake Function triggered by BOD Disabled.<br>1 = Brake Function triggered by BOD Enabled.                                                         |
| [0]    | CSSBRKEN    | <b>Clock Security System Detection Trigger EPWM Brake Function 0 Enable Bit</b><br>0 = Brake Function triggered by CSS detection Disabled.<br>1 = Brake Function triggered by CSS detection Enabled.                         |

**EPWM Brake Edge Detect Control Register 0\_1, 2\_3, 4\_5 (EPWM\_BRKCTL0\_1, 2\_3, 4\_5)**

| Register        | Offset        | R/W | Description                                 |  |  | Reset Value |
|-----------------|---------------|-----|---------------------------------------------|--|--|-------------|
| EPWM_BRKCTL_0_1 | EPWMx_BA+0xC8 | R/W | EPWM Brake Edge Detect Control Register 0/1 |  |  | 0x0000_0000 |
| EPWM_BRKCTL_2_3 | EPWMx_BA+0xCC | R/W | EPWM Brake Edge Detect Control Register 2/3 |  |  | 0x0000_0000 |
| EPWM_BRKCTL_4_5 | EPWMx_BA+0xD0 | R/W | EPWM Brake Edge Detect Control Register 4/5 |  |  | 0x0000_0000 |

|          |          |          |          |          |    |          |          |
|----------|----------|----------|----------|----------|----|----------|----------|
| 31       | 30       | 29       | 28       | 27       | 26 | 25       | 24       |
| Reserved |          |          | EADCLBEN | Reserved |    |          |          |
| 23       | 22       | 21       | 20       | 19       | 18 | 17       | 16       |
| Reserved |          |          | EADCEBEN | BRKAODD  |    | BRKAEVEN |          |
| 15       | 14       | 13       | 12       | 11       | 10 | 9        | 8        |
| SYSLBEN  | Reserved | BRKP1LEN | BRKP0LEN | Reserved |    | CPO1LBEN | CPO0LBEN |
| 7        | 6        | 5        | 4        | 3        | 2  | 1        | 0        |
| SYSEBEN  | Reserved | BRKP1EEN | BRKP0EEN | Reserved |    | CPO1EBEN | CPO0EBEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [28]    | EADCLBEN    | <b>Enable EADC Result Monitor (EADCRM) As Level-detect Brake Source (Write Protect)</b><br>0 = EADCRM as level-detect brake source Disabled.<br>1 = EADCRM as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                 |
| [27:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [20]    | EADCEBEN    | <b>Enable EADC Result Monitor (EADCRM) As Edge-detect Brake Source (Write Protect)</b><br>0 = EADCRM as edge-detect brake source Disabled.<br>1 = EADCRM as edge-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                    |
| [19:18] | BRKAODD     | <b>EPWM Brake Action Select for Odd Channel (Write Protect)</b><br>00 = EPWMx brake event will not affect odd channels output.<br>01 = EPWM odd channel output tri-state when EPWMx brake event happened.<br>10 = EPWM odd channel output low level when EPWMx brake event happened.<br>11 = EPWM odd channel output high level when EPWMx brake event happened.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [17:16] | BRKAEVEN    | <b>EPWM Brake Action Select for Even Channel (Write Protect)</b><br>00 = EPWMx brake event will not affect even channels output.<br>01 = EPWM even channel output tri-state when EPWMx brake event happened.<br>10 = EPWM even channel output low level when EPWMx brake event happened.                                                                                                                                                     |

|         |                 |                                                                                                                                                                                                                                                                                           |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 11 = EPWM even channel output high level when EPWMx brake event happened.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                     |
| [15]    | <b>SYSLBEN</b>  | <b>Enable System Fail As Level-detect Brake Source (Write Protect)</b><br>0 = System Fail condition as level-detect brake source Disabled.<br>1 = System Fail condition as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [14]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                 |
| [13]    | <b>BRKP1LEN</b> | <b>Enable BKP1 Pin As Level-detect Brake Source (Write Protect)</b><br>0 = EPWMx_BRAKE1 pin as level-detect brake source Disabled.<br>1 = EPWMx_BRAKE1 pin as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.              |
| [12]    | <b>BRKPOLEN</b> | <b>Enable BKP0 Pin As Level-detect Brake Source (Write Protect)</b><br>0 = EPWMx_BRAKE0 pin as level-detect brake source Disabled.<br>1 = EPWMx_BRAKE0 pin as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.              |
| [11:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                 |
| [9]     | <b>CPO1LBEN</b> | <b>Enable ACMP1_O Digital Output As Level-detect Brake Source (Write Protect)</b><br>0 = ACMP1_O as level-detect brake source Disabled.<br>1 = ACMP1_O as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                  |
| [8]     | <b>CPO0LBEN</b> | <b>Enable ACMP0_O Digital Output As Level-detect Brake Source (Write Protect)</b><br>0 = ACMP0_O as level-detect brake source Disabled.<br>1 = ACMP0_O as level-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                  |
| [7]     | <b>SYSEBEN</b>  | <b>Enable System Fail As Edge-detect Brake Source (Write Protect)</b><br>0 = System Fail condition as edge-detect brake source Disabled.<br>1 = System Fail condition as edge-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |
| [6]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                 |
| [5]     | <b>BRKP1EEN</b> | <b>Enable EPWMx_BRAKE1 Pin As Edge-detect Brake Source (Write Protect)</b><br>0 = EPWMx_BRAKE1 pin as edge-detect brake source Disabled.<br>1 = EPWMx_BRAKE1 pin as edge-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.         |
| [4]     | <b>BRKPOEEN</b> | <b>Enable EPWMx_BRAKE0 Pin As Edge-detect Brake Source (Write Protect)</b><br>0 = EPWMx_BRAKE0 pin as edge-detect brake source Disabled.<br>1 = EPWMx_BRAKE0 pin as edge-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.         |
| [3:2]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                 |
| [1]     | <b>CPO1EBEN</b> | <b>Enable ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)</b><br>0 = ACMP1_O as edge-detect brake source Disabled.<br>1 = ACMP1_O as edge-detect brake source Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register                      |
| [0]     | <b>CPO0EBEN</b> | <b>Enable ACMP0_O Digital Output As Edge-detect Brake Source (Write Protect)</b><br>0 = ACMP0_O as edge-detect brake source Disabled.                                                                                                                                                     |

|  |                                                  |
|--|--------------------------------------------------|
|  | 1 = ACMP0_O as edge-detect brake source Enabled. |
|--|--------------------------------------------------|

**Note:** This bit is write protected. Refer to SYS\_REGLCTL register.

**EPWM Pin Polar Inverse Control (EPWM\_POLCTL)**

| Register    | Offset        | R/W | Description                     | Reset Value |
|-------------|---------------|-----|---------------------------------|-------------|
| EPWM_POLCTL | EPWMx_BA+0xD4 | R/W | EPWM Pin Polar Inverse 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 |    | PINV5 | PINV4 | PINV3 | PINV2 | PINV1 | PINV0 |

| Bits            | Description |                                                                                                                                                                                                                       |
|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                                                             |
| [n]<br>n=0,1..5 | PINVn       | <p><b>EPWM PIN Polar Inverse Control</b></p> <p>The register controls polarity state of EPWM output.<br/>           0 = EPWM output polar inverse Disabled.<br/>           1 = EPWM output polar inverse Enabled.</p> |

**EPWM Output Enable Register (EPWM\_POEN)**

| Register  | Offset        | R/W | Description                 |  |  |  | Reset Value |
|-----------|---------------|-----|-----------------------------|--|--|--|-------------|
| EPWM_POEN | EPWMx_BA+0xD8 | R/W | EPWM Output Enable Register |  |  |  | 0x0000_0000 |

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

| Bits            | Description |                                                                                                  |
|-----------------|-------------|--------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                        |
| [n]<br>n=0,1..5 | POENn       | <b>EPWM Pin Output Enable Bits</b><br>0 = EPWM pin at tri-state.<br>1 = EPWM pin in output mode. |

**EPWM Software Brake Control Register (EPWM\_SWBRK)**

| Register   | Offset        | R/W | Description                          |  |  |  | Reset Value |
|------------|---------------|-----|--------------------------------------|--|--|--|-------------|
| EPWM_SWBRK | EPWMx_BA+0xDC | W   | EPWM Software Brake Control Register |  |  |  | 0x0000_0000 |

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

| Bits               | Description |                                                                                                                                                                                                                                                                          |
|--------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                |
| [8+n/2]<br>n=0,2,4 | BRKLTRGn    | <p><b>EPWM Level Brake Software Trigger (Write Only) (Write Protect)</b><br/>           Write 1 to this bit will trigger level brake, and set BRKLIFn to 1 in EPWM_INTSTS1 register.</p> <p><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.</p> |
| [7:3]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                |
| [n/2]<br>n=0,2,4   | BRKETRGn    | <p><b>EPWM Edge Brake Software Trigger (Write Only) (Write Protect)</b><br/>           Write 1 to this bit will trigger edge brake, and set BRKEIFn to 1 in EPWM_INTSTS1 register.</p> <p><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.</p>   |

**EPWM Interrupt Enable Register 0 (EPWM\_INTEN0)**

| Register    | Offset        | R/W | Description                      |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------------|--|--|--|-------------|
| EPWM_INTEN0 | EPWMx_BA+0xE0 | R/W | EPWM Interrupt Enable Register 0 |  |  |  | 0x0000_0000 |

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

| Bits               | Description |                                                                                                                                                                                                                                                                                                                        |
|--------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                              |
| [24+n]<br>n=0,1..5 | CMPDIENn    | <p><b>EPWM Compare Down Count Interrupt Enable Bits</b><br/>           0 = Compare down count interrupt Disabled.<br/>           1 = Compare down count interrupt Enabled.</p> <p><b>Note:</b> In complementary mode, CMPDIEN1, 3, 5 is used as another CMPDIEN for channel 0, 2, 4.</p>                               |
| [23:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                              |
| [16+n]<br>n=0,1..5 | CMPUIENn    | <p><b>EPWM Compare Up Count Interrupt Enable Bits</b><br/>           0 = Compare up count interrupt Disabled.<br/>           1 = Compare up count interrupt Enabled.</p> <p><b>Note:</b> In complementary mode, CMPUIEN1, 3, 5 is used as another CMPUIEN for channel 0, 2, 4.</p>                                     |
| [15:14]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                              |
| [8+n]<br>n=0,1..5  | PIEnn       | <p><b>EPWM Period Point Interrupt Enable Bits</b><br/>           0 = Period point interrupt Disabled.<br/>           1 = Period point interrupt Enabled.</p> <p><b>Note1:</b> When up-down counter type period point means center point.<br/> <b>Note2:</b> Odd channels will read always 0 at complementary mode.</p> |
| [7:6]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                              |
| [n]<br>n=0,1..5    | ZIEnn       | <p><b>EPWM Zero Point Interrupt Enable Bits</b><br/>           0 = Zero point interrupt Disabled.<br/>           1 = Zero point interrupt Enabled.</p> <p><b>Note:</b> Odd channels will read always 0 at complementary mode.</p>                                                                                      |

**EPWM Interrupt Enable Register 1 (EPWM\_INTEN1)**

| Register    | Offset        | R/W | Description                      | Reset Value |
|-------------|---------------|-----|----------------------------------|-------------|
| EPWM_INTEN1 | EPWMx_BA+0xE4 | R/W | EPWM Interrupt Enable Register 1 | 0x0000_0000 |

|          |    |    |    |    |            |            |            |
|----------|----|----|----|----|------------|------------|------------|
| 31       | 30 | 29 | 28 | 27 | 26         | 25         | 24         |
| Reserved |    |    |    |    |            |            |            |
| 23       | 22 | 21 | 20 | 19 | 18         | 17         | 16         |
| Reserved |    |    |    |    |            |            |            |
| 15       | 14 | 13 | 12 | 11 | 10         | 9          | 8          |
| Reserved |    |    |    |    | 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  | <b>EPWM Level-detect Brake Interrupt Enable for Channel4/5 (Write Protect)</b><br>0 = Level-detect Brake interrupt for channel4/5 Disabled.<br>1 = Level-detect Brake interrupt for channel4/5 Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [9]     | BRKLIEN2_3  | <b>EPWM Level-detect Brake Interrupt Enable for Channel2/3 (Write Protect)</b><br>0 = Level-detect Brake interrupt for channel2/3 Disabled.<br>1 = Level-detect Brake interrupt for channel2/3 Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [8]     | BRKLIENO_1  | <b>EPWM Level-detect Brake Interrupt Enable for Channel0/1 (Write Protect)</b><br>0 = Level-detect Brake interrupt for channel0/1 Disabled.<br>1 = Level-detect Brake interrupt for channel0/1 Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                           |
| [2]     | BRKEIEN4_5  | <b>EPWM Edge-detect Brake Interrupt Enable for Channel4/5 (Write Protect)</b><br>0 = Edge-detect Brake interrupt for channel4/5 Disabled.<br>1 = Edge-detect Brake interrupt for channel4/5 Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |
| [1]     | BRKEIEN2_3  | <b>EPWM Edge-detect Brake Interrupt Enable for Channel2/3 (Write Protect)</b><br>0 = Edge-detect Brake interrupt for channel2/3 Disabled.<br>1 = Edge-detect Brake interrupt for channel2/3 Enabled.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |
| [0]     | BRKEIENO_1  | <b>EPWM Edge-detect Brake Interrupt Enable for Channel0/1 (Write Protect)</b><br>0 = Edge-detect Brake interrupt for channel0/1 Disabled.<br>1 = Edge-detect Brake interrupt for channel0/1 Enabled.                                                                                |

|  |  |                                                                          |
|--|--|--------------------------------------------------------------------------|
|  |  | <b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
|--|--|--------------------------------------------------------------------------|

**EPWM Interrupt Flag Register 0 (EPWM\_INTSTS0)**

| Register     | Offset        | R/W | Description                    |  |  |  | Reset Value |
|--------------|---------------|-----|--------------------------------|--|--|--|-------------|
| EPWM_INTSTS0 | EPWMx_BA+0xE8 | R/W | EPWM Interrupt Flag Register 0 |  |  |  | 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       |
| Reserved |    | PIF5    | PIF4    | PIF3    | PIF2    | PIF1    | PIF0    |
| 7        | 6  | 5       | 4       | 3       | 2       | 1       | 0       |
| Reserved |    | ZIF5    | ZIF4    | ZIF3    | ZIF2    | ZIF1    | ZIF0    |

| Bits               | Description |                                                                                                                                                                                                                                                                                                |
|--------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                      |
| [24+n]<br>n=0,1..5 | CMPDIFn     | <p><b>EPWM Compare Down Count Interrupt Flag</b><br/> Flag is set by hardware when EPWM counter down count and reaches EPWM_CMPDATn, software can clear this bit by writing 1 to it.<br/> <b>Note:</b> In complementary mode, CMPDIF1, 3, 5 is used as another CMPDIF for channel 0, 2, 4.</p> |
| [23:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                      |
| [16+n]<br>n=0,1..5 | CMPUIFn     | <p><b>EPWM Compare Up Count Interrupt Flag</b><br/> Flag is set by hardware when EPWM counter up count and reaches EPWM_CMPDATn, software can clear this bit by writing 1 to it.<br/> <b>Note:</b> In complementary mode, CMPUIF1, 3, 5 is used as another CMPUIF for channel 0, 2, 4.</p>     |
| [15:14]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                      |
| [8+n]<br>n=0,1..5  | PIFn        | <p><b>EPWM Period Point Interrupt Flag</b><br/> This bit is set by hardware when EPWM counter reaches EPWM_PERIODn.<br/> <b>Note:</b> This bit can be cleared to 0 by software writing 1.</p>                                                                                                  |
| [7:6]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                      |
| [n]<br>n=0,1..5    | ZIFn        | <p><b>EPWM Zero Point Interrupt Flag</b><br/> This bit is set by hardware when EPWM counter reaches 0.<br/> <b>Note:</b> This bit can be cleared to 0 by software writing 1</p>                                                                                                                |

**EPWM Interrupt Flag Register 1 (EPWM\_INTSTS1)**

| Register     | Offset        | R/W | Description                    |  |  |  | Reset Value |
|--------------|---------------|-----|--------------------------------|--|--|--|-------------|
| EPWM_INTSTS1 | EPWMx_BA+0xEC | R/W | EPWM Interrupt Flag Register 1 |  |  |  | 0x0000_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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [29]    | BRKLSTS5    | <p><b>EPWM Channel5 Level-detect Brake Status (Read Only)</b></p> <p>0 = EPWM channel5 level-detect brake state is released.</p> <p>1 = When EPWM channel5 level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel5 at brake state.</p> <p><b>Note:</b> This bit is read only and auto cleared by hardware. When enabled brake source return to high level, EPWM will release brake state until current EPWM period finished. The EPWM waveform will start output from next full EPWM period.</p> |
| [28]    | BRKLSTS4    | <p><b>EPWM Channel4 Level-detect Brake Status (Read Only)</b></p> <p>0 = EPWM channel4 level-detect brake state is released.</p> <p>1 = When EPWM channel4 level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel4 at brake state.</p> <p><b>Note:</b> This bit is read only and auto cleared by hardware. When enabled brake source return to high level, EPWM will release brake state until current EPWM period finished. The EPWM waveform will start output from next full EPWM period.</p> |
| [27]    | BRKLSTS3    | <p><b>EPWM Channel3 Level-detect Brake Status (Read Only)</b></p> <p>0 = EPWM channel3 level-detect brake state is released.</p> <p>1 = When EPWM channel3 level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel3 at brake state.</p> <p><b>Note:</b> This bit is read only and auto cleared by hardware. When enabled brake source return to high level, EPWM will release brake state until current EPWM period finished. The EPWM waveform will start output from next full EPWM period.</p> |
| [26]    | BRKLSTS2    | <p><b>EPWM Channel2 Level-detect Brake Status (Read Only)</b></p> <p>0 = EPWM channel2 level-detect brake state is released.</p> <p>1 = When EPWM channel2 level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel2 at brake state.</p> <p><b>Note:</b> This bit is read only and auto cleared by hardware. When enabled brake source return to high level, EPWM will release brake state until current EPWM period finished. The EPWM waveform will start output from next full EPWM period.</p> |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [25]    | <b>BRKLSTS1</b> | <b>EPWM Channel1 Level-detect Brake Status (Read Only)</b><br>0 = EPWM channel1 level-detect brake state is released.<br>1 = When EPWM channel1 level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel1 at brake state.<br><b>Note:</b> This bit is read only and auto cleared by hardware. When enabled brake source return to high level, EPWM will release brake state until current EPWM period finished. The EPWM waveform will start output from next full EPWM period. |
| [24]    | <b>BRKLSTS0</b> | <b>EPWM Channel0 Level-detect Brake Status (Read Only)</b><br>0 = EPWM channel0 level-detect brake state is released.<br>1 = When EPWM channel0 level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel0 at brake state.<br><b>Note:</b> This bit is read only and auto cleared by hardware. When enabled brake source return to high level, EPWM will release brake state until current EPWM period finished. The EPWM waveform will start output from next full EPWM period. |
| [23:22] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [21]    | <b>BRKESTS5</b> | <b>EPWM Channel5 Edge-detect Brake Status (Read Only)</b><br>0 = EPWM channel5 edge-detect brake state is released.<br>1 = When EPWM channel5 edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel5 at brake state.<br><b>Note:</b> 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.  |
| [20]    | <b>BRKESTS4</b> | <b>EPWM Channel4 Edge-detect Brake Status (Read Only)</b><br>0 = EPWM channel4 edge-detect brake state is released.<br>1 = When EPWM channel4 edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel4 at brake state, writing 1 to clear.                                                                                                                                                                                                                                      |
| [19]    | <b>BRKESTS3</b> | <b>EPWM Channel3 Edge-detect Brake Status (Read Only)</b><br>0 = EPWM channel3 edge-detect brake state is released.<br>1 = When EPWM channel3 edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel3 at brake state, writing 1 to clear.                                                                                                                                                                                                                                      |
| [18]    | <b>BRKESTS2</b> | <b>EPWM Channel2 Edge-detect Brake Status (Read Only)</b><br>0 = EPWM channel2 edge-detect brake state is released.<br>1 = When EPWM channel2 edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel2 at brake state, writing 1 to clear.                                                                                                                                                                                                                                      |
| [17]    | <b>BRKESTS1</b> | <b>EPWM Channel1 Edge-detect Brake Status (Read Only)</b><br>0 = EPWM channel1 edge-detect brake state is released.<br>1 = When EPWM channel1 edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel1 at brake state, writing 1 to clear.                                                                                                                                                                                                                                      |
| [16]    | <b>BRKESTS0</b> | <b>EPWM Channel0 Edge-detect Brake Status (Read Only)</b><br>0 = EPWM channel0 edge-detect brake state is released.<br>1 = When EPWM channel0 edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the EPWM channel0 at brake state, writing 1 to clear.                                                                                                                                                                                                                                      |
| [15:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [13]    | <b>BRKLIF5</b>  | <b>EPWM Channel5 Level-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel5 level-detect brake event do not happened.<br>1 = When EPWM channel5 level-detect brake event happened, this bit is set to 1, writing 1                                                                                                                                                                                                                                                                                                               |

|       |          |                                                                                                                                                                                                                                                                                                                          |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                    |
| [12]  | BRKLIF4  | <b>EPWM Channel4 Level-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel4 level-detect brake event do not happened.<br>1 = When EPWM channel4 level-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [11]  | BRKLIF3  | <b>EPWM Channel3 Level-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel3 level-detect brake event do not happened.<br>1 = When EPWM channel3 level-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [10]  | BRKLIF2  | <b>EPWM Channel2 Level-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel2 level-detect brake event do not happened.<br>1 = When EPWM channel2 level-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [9]   | BRKLIF1  | <b>EPWM Channel1 Level-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel1 level-detect brake event do not happened.<br>1 = When EPWM channel1 level-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [8]   | BRKLIF0  | <b>EPWM Channel0 Level-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel0 level-detect brake event do not happened.<br>1 = When EPWM channel0 level-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:6] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                |
| [5]   | BRKEIF5  | <b>EPWM Channel5 Edge-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel5 edge-detect brake event do not happened.<br>1 = When EPWM channel5 edge-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |
| [4]   | BRKEIF4  | <b>EPWM Channel4 Edge-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel4 edge-detect brake event do not happened.<br>1 = When EPWM channel4 edge-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |
| [3]   | BRKEIF3  | <b>EPWM Channel3 Edge-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel3 edge-detect brake event do not happened.<br>1 = When EPWM channel3 edge-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |
| [2]   | BRKEIF2  | <b>EPWM Channel2 Edge-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel2 edge-detect brake event do not happened.<br>1 = When EPWM channel2 edge-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.    |

|     |                |                                                                                                                                                                                                                                                                                                                       |
|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | <b>BRKEIF1</b> | <b>EPWM Channel1 Edge-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel1 edge-detect brake event do not happened.<br>1 = When EPWM channel1 edge-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |
| [0] | <b>BRKEIF0</b> | <b>EPWM Channel0 Edge-detect Brake Interrupt Flag (Write Protect)</b><br>0 = EPWM channel0 edge-detect brake event do not happened.<br>1 = When EPWM channel0 edge-detect brake event happened, this bit is set to 1, writing 1 to clear.<br><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register. |

**EPWM Trigger DAC Enable Register (EPWM\_DACTRGEN)**

| Register      | Offset        | R/W | Description                      |  |  |  | Reset Value |
|---------------|---------------|-----|----------------------------------|--|--|--|-------------|
| EPWM_DACTRGEN | EPWMx_BA+0xF4 | R/W | EPWM Trigger DAC Enable Register |  |  |  | 0x0000_0000 |

|          |    |          |          |          |          |          |          |
|----------|----|----------|----------|----------|----------|----------|----------|
| 31       | 30 | 29       | 28       | 27       | 26       | 25       | 24       |
| Reserved |    | CDTRGEN5 | CDTRGEN4 | CDTRGEN3 | CDTRGEN2 | CDTRGEN1 | CDTRGEN0 |
| 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
| Reserved |    | CUTRGEN5 | CUTRGEN4 | CUTRGEN3 | CUTRGEN2 | CUTRGEN1 | CUTRGEN0 |
| 15       | 14 | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved |    | PTE5     | PTE4     | PTE3     | PTE2     | PTE1     | PTE0     |
| 7        | 6  | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved |    | ZTE5     | ZTE4     | ZTE3     | ZTE2     | ZTE1     | ZTE0     |

| Bits               | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [24+n]<br>n=0,1..5 | CDTRGEN     | <p><b>EPWM Compare Down Count Point Trigger DAC Enable Bits</b><br/>           EPWM can trigger DAC to start action when EPWM counter down count to CMPDAT if this bit is set to1.<br/>           0 = EPWM Compare Down count point trigger DAC function Disabled.<br/>           1 = EPWM Compare Down count point trigger DAC function Enabled.</p> <p><b>Note1:</b> This bit should keep at 0 when EPWM counter operating in up counter type.</p> <p><b>Note2:</b> In complementary mode, CDTRGE1, 3, 5 is used as another CDTRGE for channel 0, 2, 4.</p> |
| [23:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [16+n]<br>n=0,1..5 | CUTRGEN     | <p><b>EPWM Compare Up Count Point Trigger DAC Enable Bits</b><br/>           EPWM can trigger DAC to start action when EPWM counter counts up to CMPDAT if this bit is set to1.<br/>           0 = EPWM Compare Up point trigger DAC function Disabled.<br/>           1 = EPWM Compare Up point trigger DAC function Enabled.</p> <p><b>Note1:</b> This bit should keep at 0 when EPWM counter operating in down counter type.</p> <p><b>Note2:</b> In complementary mode, CUTRGE1, 3, 5 is used as another CUTRGE for channel 0, 2, 4.</p>                  |
| [15:14]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [8+n]<br>n=0,1..5  | PTEn        | <p><b>EPWM Period Point Trigger DAC Enable Bits</b><br/>           EPWM can trigger DAC to start action when EPWM counter counts up to (PERIODn+1) if this bit is set to1.<br/>           0 = EPWM period point trigger DAC function Disabled.<br/>           1 = EPWM period point trigger DAC function Enabled.</p>                                                                                                                                                                                                                                         |
| [7:6]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [n]                | ZTEn        | <p><b>EPWM Zero Point Trigger DAC Enable Bits</b><br/>           EPWM can trigger EADC/DAC/DMA to start action when EPWM counter down count to</p>                                                                                                                                                                                                                                                                                                                                                                                                            |

|          |  |                                                                                                                                             |
|----------|--|---------------------------------------------------------------------------------------------------------------------------------------------|
| n=0,1..5 |  | zero if this bit is set to1.<br>0 = EPWM period point trigger DAC function Disabled.<br>1 = EPWM period point trigger DAC function Enabled. |
|----------|--|---------------------------------------------------------------------------------------------------------------------------------------------|

**EPWM Trigger EADC Source Select Register 0 (EPWM\_EADCTS0)**

| Register      | Offset        | R/W | Description                                |  |  |  |  | Reset Value |
|---------------|---------------|-----|--------------------------------------------|--|--|--|--|-------------|
| EPWM_EADC_TS0 | EPWMx_BA+0xF8 | R/W | EPWM Trigger EADC Source Select Register 0 |  |  |  |  | 0x0000_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  |
| TRGEN0 | Reserved |    |    |    | TRGSEL0 |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | TRGEN3      | <b>EPWM_CH3 Trigger EADC Enable Bit</b><br>0 = EPWM_CH3 Trigger EADC function Disabled.<br>1 = EPWM_CH3 Trigger EADC function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [30:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [27:24] | TRGSEL3     | <b>EPWM_CH3 Trigger EADC Source Select</b><br>0000 = EPWM_CH2 zero point.<br>0001 = EPWM_CH2 period point.<br>0010 = EPWM_CH2 zero or period point.<br>0011 = EPWM_CH2 up-count CMPDAT point.<br>0100 = EPWM_CH2 down-count CMPDAT point.<br>0101 = EPWM_CH3 zero point.<br>0110 = EPWM_CH3 period point.<br>0111 = EPWM_CH3 zero or period point.<br>1000 = EPWM_CH3 up-count CMPDAT point.<br>1001 = EPWM_CH3 down-count CMPDAT point.<br>1010 = EPWM_CH0 up-count free CMPDAT point.<br>1011 = EPWM_CH0 down-count free CMPDAT point.<br>1100 = EPWM_CH2 up-count free CMPDAT point.<br>1101 = EPWM_CH2 down-count free CMPDAT point.<br>1110 = EPWM_CH4 up-count free CMPDAT point.<br>1111 = EPWM_CH4 down-count free CMPDAT point. |
| [23]    | TRGEN2      | <b>EPWM_CH2 Trigger EADC Enable Bit</b><br>0 = EPWM_CH2 Trigger EADC function Disabled.<br>1 = EPWM_CH2 Trigger EADC function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [22:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [19:16] | TRGSEL2     | <b>EPWM_CH2 Trigger EADC Source Select</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|         |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | 0000 = EPWM_CH2 zero point.<br>0001 = EPWM_CH2 period point.<br>0010 = EPWM_CH2 zero or period point.<br>0011 = EPWM_CH2 up-count CMPDAT point.<br>0100 = EPWM_CH2 down-count CMPDAT point.<br>0101 = EPWM_CH3 zero point.<br>0110 = EPWM_CH3 period point.<br>0111 = EPWM_CH3 zero or period point.<br>1000 = EPWM_CH3 up-count CMPDAT point.<br>1001 = EPWM_CH3 down-count CMPDAT point.<br>1010 = EPWM_CH0 up-count free CMPDAT point.<br>1011 = EPWM_CH0 down-count free CMPDAT point.<br>1100 = EPWM_CH2 up-count free CMPDAT point.<br>1101 = EPWM_CH2 down-count free CMPDAT point.<br>1110 = EPWM_CH4 up-count free CMPDAT point.<br>1111 = EPWM_CH4 down-count free CMPDAT point.                                               |
| [15]    | TRGEN1   | <b>EPWM_CH1 Trigger EADC Enable Bit</b><br>0 = EPWM_CH1 Trigger EADC function Disabled.<br>1 = EPWM_CH1 Trigger EADC function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [14:12] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [11:8]  | TRGSEL1  | <b>EPWM_CH1 Trigger EADC Source Select</b><br>0000 = EPWM_CH0 zero point.<br>0001 = EPWM_CH0 period point.<br>0010 = EPWM_CH0 zero or period point.<br>0011 = EPWM_CH0 up-count CMPDAT point.<br>0100 = EPWM_CH0 down-count CMPDAT point.<br>0101 = EPWM_CH1 zero point.<br>0110 = EPWM_CH1 period point.<br>0111 = EPWM_CH1 zero or period point.<br>1000 = EPWM_CH1 up-count CMPDAT point.<br>1001 = EPWM_CH1 down-count CMPDAT point.<br>1010 = EPWM_CH0 up-count free CMPDAT point.<br>1011 = EPWM_CH0 down-count free CMPDAT point.<br>1100 = EPWM_CH2 up-count free CMPDAT point.<br>1101 = EPWM_CH2 down-count free CMPDAT point.<br>1110 = EPWM_CH4 up-count free CMPDAT point.<br>1111 = EPWM_CH4 down-count free CMPDAT point. |
| [7]     | TRGEN0   | <b>EPWM_CH0 Trigger EADC Enable Bit</b><br>0 = EPWM_CH0 Trigger EADC function Disabled.<br>1 = EPWM_CH0 Trigger EADC function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [6:4]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [3:0]   | TRGSEL0  | <b>EPWM Trigger EADC Source Select</b><br>0000 = EPWM_CH0 zero point.<br>0001 = EPWM_CH0 period point.<br>0010 = EPWM_CH0 zero or period point.<br>0011 = EPWM_CH0 up-count CMPDAT point.<br>0100 = EPWM_CH0 down-count CMPDAT point.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | <p>0101 = EPWM_CH1 zero point.<br/>0110 = EPWM_CH1 period point.<br/>0111 = EPWM_CH1 zero or period point.<br/>1000 = EPWM_CH1 up-count CMPDAT point.<br/>1001 = EPWM_CH1 down-count CMPDAT point.<br/>1010 = EPWM_CH0 up-count free CMPDAT point.<br/>1011 = EPWM_CH0 down-count free CMPDAT point.<br/>1100 = EPWM_CH2 up-count free CMPDAT point.<br/>1101 = EPWM_CH2 down-count free CMPDAT point.<br/>1110 = EPWM_CH4 up-count free CMPDAT point.<br/>1111 = EPWM_CH4 down-count free CMPDAT point.</p> |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**EPWM Trigger EADC Source Select Register 1 (EPWM\_EADCTS1)**

| Register      | Offset        | R/W | Description                                |  |  |  |  | Reset Value |
|---------------|---------------|-----|--------------------------------------------|--|--|--|--|-------------|
| EPWM_EADC_TS1 | EPWMx_BA+0xFC | R/W | EPWM Trigger EADC Source Select Register 1 |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [15]    | TRGEN5      | <b>EPWM_CH5 Trigger EADC Enable Bit</b><br>0 = EPWM_CH5 Trigger EADC function Disabled.<br>1 = EPWM_CH5 Trigger EADC function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [14:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [11:8]  | TRGSEL5     | <b>EPWM_CH5 Trigger EADC Source Select</b><br>0000 = EPWM_CH4 zero point.<br>0001 = EPWM_CH4 period point.<br>0010 = EPWM_CH4 zero or period point.<br>0011 = EPWM_CH4 up-count CMPDAT point.<br>0100 = EPWM_CH4 down-count CMPDAT point.<br>0101 = EPWM_CH5 zero point.<br>0110 = EPWM_CH5 period point.<br>0111 = EPWM_CH5 zero or period point.<br>1000 = EPWM_CH5 up-count CMPDAT point.<br>1001 = EPWM_CH5 down-count CMPDAT point.<br>1010 = EPWM_CH0 up-count free CMPDAT point.<br>1011 = EPWM_CH0 down-count free CMPDAT point.<br>1100 = EPWM_CH2 up-count free CMPDAT point.<br>1101 = EPWM_CH2 down-count free CMPDAT point.<br>1110 = EPWM_CH4 up-count free CMPDAT point.<br>1111 = EPWM_CH4 down-count free CMPDAT point. |
| [7]     | TRGEN4      | <b>EPWM_CH4 Trigger EADC Enable Bit</b><br>0 = EPWM_CH4 Trigger EADC function Disabled.<br>1 = EPWM_CH4 Trigger EADC function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [6:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|       |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:0] | TRGSEL4 | <b>EPWM_CH4 Trigger EADC Source Select</b><br>0000 = EPWM_CH4 zero point.<br>0001 = EPWM_CH4 period point.<br>0010 = EPWM_CH4 zero or period point.<br>0011 = EPWM_CH4 up-count CMPDAT point.<br>0100 = EPWM_CH4 down-count CMPDAT point.<br>0101 = EPWM_CH5 zero point.<br>0110 = EPWM_CH5 period point.<br>0111 = EPWM_CH5 zero or period point.<br>1000 = EPWM_CH5 up-count CMPDAT point.<br>1001 = EPWM_CH5 down-count CMPDAT point.<br>1010 = EPWM_CH0 up-count free CMPDAT point.<br>1011 = EPWM_CH0 down-count free CMPDAT point.<br>1100 = EPWM_CH2 up-count free CMPDAT point.<br>1101 = EPWM_CH2 down-count free CMPDAT point.<br>1110 = EPWM_CH4 up-count free CMPDAT point.<br>1111 = EPWM_CH4 down-count free CMPDAT point. |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**EPWM Free Trigger Compare Register 0\_1, 2\_3, 4\_5 (EPWM\_FTCMPDAT0\_1, 2, 3, 4, 5)**

| Register         | Offset         | R/W | Description                            |  |  |  | Reset Value |
|------------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| EPWM_FTCMPDAT0_1 | EPWMx_BA+0x100 | R/W | EPWM Free Trigger Compare Register 0/1 |  |  |  | 0x0000_0000 |
| EPWM_FTCMPDAT2_3 | EPWMx_BA+0x104 | R/W | EPWM Free Trigger Compare Register 2/3 |  |  |  | 0x0000_0000 |
| EPWM_FTCMPDAT4_5 | EPWMx_BA+0x108 | R/W | EPWM Free Trigger Compare Register 4/5 |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                |
| [15:0]  | FTCMP       | <b>EPWM Free Trigger Compare Register</b><br>FTCMP use to compare with even CNTR to trigger EADC. FTCMPDAT0, 2, 4 corresponding complementary pairs EPWM_CH0 and EPWM_CH1, EPWM_CH2 and EPWM_CH3, EPWM_CH4 and EPWM_CH5. |

**EPWM Synchronous Start Control Register (EPWM\_SSCTL)**

| Register   | Offset         | R/W | Description                             |  |  |  | Reset Value |
|------------|----------------|-----|-----------------------------------------|--|--|--|-------------|
| EPWM_SSCTL | EPWMx_BA+0x110 | R/W | EPWM Synchronous Start Control Register |  |  |  | 0x0000_0000 |

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

| Bits            | Description       |                                                                                                                                                                                                                                                                                                                         |
|-----------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10]         | Reserved          | Reserved.                                                                                                                                                                                                                                                                                                               |
| [9:8]           | SSRC              | <b>EPWM Synchronous Start Source Select Bits</b><br>00 = Synchronous start source come from EPWM0.<br>01 = Synchronous start source come from EPWM1.<br>10 = Synchronous start source come from BPWM0.<br>11 = Synchronous start source come from BPWM1.                                                                |
| [7:6]           | Reserved          | Reserved.                                                                                                                                                                                                                                                                                                               |
| [n]<br>n=0,1..5 | SSEN <sub>n</sub> | <b>EPWM Synchronous Start Function Enable Bits</b><br>When synchronous start function is enabled, the EPWM counter enable register (EPWM_CNTEN) can be enabled by writing EPWM synchronous start trigger bit (CNTSEN).<br>0 = EPWM synchronous start function Disabled.<br>1 = EPWM synchronous start function Enabled. |

**EPWM Synchronous Start Trigger Register (EPWM\_SSTRG)**

| Register   | Offset         | R/W | Description                             |  |  |  |  | Reset Value |
|------------|----------------|-----|-----------------------------------------|--|--|--|--|-------------|
| EPWM_SSTRG | EPWMx_BA+0x114 | W   | EPWM Synchronous Start Trigger Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [0]    | CNTSEN      | <p><b>EPWM Counter Synchronous Start Enable (Write Only)</b></p> <p>PMW counter synchronous enable function is used to make selected EPWM channels (include EPWM0_CHx and EPWM1_CHx) start counting at the same time.</p> <p>\Writing this bit to 1 will also set the counter enable bit (CNTEEn, n denotes channel 0 to 5) if correlated EPWM channel counter synchronous start function is enabled.</p> |

**EPWM Leading Edge Blanking Control Register (EPWM\_LEBCTL)**

| Register    | Offset         | R/W | Description                                 | Reset Value |
|-------------|----------------|-----|---------------------------------------------|-------------|
| EPWM_LEBCTL | EPWMx_BA+0x118 | R/W | EPWM Leading Edge Blanking Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                             |
| [17:16] | TRGTYPE     | <b>EPWM Leading Edge Blanking Trigger Type</b><br>0 = When detect leading edge blanking source rising edge, blanking counter start counting.<br>1 = When detect leading edge blanking source falling edge, blanking counter start counting.<br>2 = When detect leading edge blanking source rising or falling edge, blanking counter start counting.<br>3 = Reserved. |
| [15:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                             |
| [10]    | SRcen4      | <b>EPWM Leading Edge Blanking Source From EPWM_CH4 Enable Bit</b><br>0 = EPWM Leading Edge Blanking Source from EPWM_CH4 Disabled.<br>1 = EPWM Leading Edge Blanking Source from EPWM_CH4 Enabled.                                                                                                                                                                    |
| [9]     | SRcen2      | <b>EPWM Leading Edge Blanking Source From EPWM_CH2 Enable Bit</b><br>0 = EPWM Leading Edge Blanking Source from EPWM_CH2 Disabled.<br>1 = EPWM Leading Edge Blanking Source from EPWM_CH2 Enabled.                                                                                                                                                                    |
| [8]     | SRcen0      | <b>EPWM Leading Edge Blanking Source From EPWM_CH0 Enable Bit</b><br>0 = EPWM Leading Edge Blanking Source from EPWM_CH0 Disabled.<br>1 = EPWM Leading Edge Blanking Source from EPWM_CH0 Enabled.                                                                                                                                                                    |
| [7:1]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                             |
| [0]     | LEBEN       | <b>EPWM Leading Edge Blanking Enable Bit</b><br>0 = EPWM Leading Edge Blanking Disabled.<br>1 = EPWM Leading Edge Blanking Enabled.                                                                                                                                                                                                                                   |

**EPWM Leading Edge Blanking Counter Register (EPWM\_LBCNT)**

| Register   | Offset         | R/W | Description                                 | Reset Value |
|------------|----------------|-----|---------------------------------------------|-------------|
| EPWM_LBCNT | EPWMx_BA+0x11C | R/W | EPWM Leading Edge Blanking Counter Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                 |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                       |
| [8:0]  | LEBCNT      | <b>EPWM Leading Edge Blanking Counter</b><br>This counter value decides leading edge blanking window size. Blanking window size = LEBCNT+1, and LEB counter clock base is ECLK. |

EPWM Status Register (EPWM\_STATUS)

| Register    | Offset         | R/W | Description          |  |  |  | Reset Value |
|-------------|----------------|-----|----------------------|--|--|--|-------------|
| EPWM_STATUS | EPWMx_BA+0x120 | R/W | EPWM Status Register |  |  |  | 0x0000_0000 |

|          |           |           |           |           |           |           |          |
|----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|
| 31       | 30        | 29        | 28        | 27        | 26        | 25        | 24       |
| Reserved |           |           |           |           |           |           | DACTRGF  |
| 23       | 22        | 21        | 20        | 19        | 18        | 17        | 16       |
| Reserved | EADCTRGF5 | EADCTRGF4 | EADCTRGF3 | EADCTRGF2 | EADCTRGF1 | EADCTRGF0 |          |
| 15       | 14        | 13        | 12        | 11        | 10        | 9         | 8        |
| Reserved |           |           |           |           | SYNCINF4  | SYNCINF2  | SYNCINFO |
| 7        | 6         | 5         | 4         | 3         | 2         | 1         | 0        |
| Reserved |           | CNTMAXF5  | CNTMAXF4  | CNTMAXF3  | CNTMAXF2  | CNTMAXF1  | CNTMAXF0 |

| Bits               | Description |                                                                                                                                                                                                                                                   |
|--------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25]            | Reserved    | Reserved.                                                                                                                                                                                                                                         |
| [24]               | DACTRGF     | <b>DAC Start of Conversion Flag</b><br>0 = No DAC start of conversion trigger event has occurred.<br>1 = An DAC start of conversion trigger event has occurred.<br><b>Note:</b> This bit can be cleared by software writing 1.                    |
| [23:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                         |
| [16+n]<br>n=0,1..5 | EADCTRGFn   | <b>EADC Start of Conversion Flag</b><br>0 = No EADC start of conversion trigger event has occurred.<br>1 = An EADC start of conversion trigger event has occurred.<br><b>Note:</b> This bit can be cleared by software writing 1.                 |
| [15:11]            | Reserved    | Reserved.                                                                                                                                                                                                                                         |
| [8+n/2]<br>n=0,2,4 | SYNCINFn    | <b>Input Synchronization Latched Flag</b><br>0 = No SYNC_IN event has occurred.<br>1 = An SYNC_IN event has occurred.<br><b>Note:</b> This bit can be cleared by software writing 1.                                                              |
| [7:6]              | Reserved    | Reserved.                                                                                                                                                                                                                                         |
| [n]<br>n=0,1..5    | CNTMAXFn    | <b>Time-base Counter Equal to 0xFFFF Latched Flag</b><br>0 = The time-base counter never reached its maximum value 0xFFFF.<br>1 = The time-base counter reached its maximum value.<br><b>Note:</b> This bit can be cleared by software writing 1. |

**EPWM Interrupt Flag Accumulator Register (EPWM\_IFAn)**

| Register  | Offset         | R/W | Description                                |  |  |  | Reset Value |
|-----------|----------------|-----|--------------------------------------------|--|--|--|-------------|
| EPWM_IFA0 | EPWMx_BA+0x130 | R/W | EPWM Interrupt Flag Accumulator Register 0 |  |  |  | 0x0000_0000 |
| EPWM_IFA1 | EPWMx_BA+0x134 | R/W | EPWM Interrupt Flag Accumulator Register 1 |  |  |  | 0x0000_0000 |
| EPWM_IFA2 | EPWMx_BA+0x138 | R/W | EPWM Interrupt Flag Accumulator Register 2 |  |  |  | 0x0000_0000 |
| EPWM_IFA3 | EPWMx_BA+0x13C | R/W | EPWM Interrupt Flag Accumulator Register 3 |  |  |  | 0x0000_0000 |
| EPWM_IFA4 | EPWMx_BA+0x140 | R/W | EPWM Interrupt Flag Accumulator Register 4 |  |  |  | 0x0000_0000 |
| EPWM_IFA5 | EPWMx_BA+0x144 | R/W | EPWM Interrupt Flag Accumulator Register 5 |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | IFAEN       | <b>EPWM_CHn Interrupt Flag Accumulator Enable Bits</b><br>0 = EPWM_CHn interrupt flag accumulator Disabled.<br>1 = EPWM_CHn interrupt flag accumulator Enabled.                                                                                                  |
| [30]    | Reserved    | Reserved.                                                                                                                                                                                                                                                        |
| [29:28] | IFASEL      | <b>EPWM_CHn Interrupt Flag Accumulator Source Select</b><br>00 = CNT equal to Zero in channel n.<br>01 = CNT equal to PERIOD in channel n.<br>10 = CNT equal to CMPU in channel n.<br>11 = CNT equal to CMPD in channel n.                                       |
| [27:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                        |
| [15:0]  | IFACNT      | <b>EPWM_CHn Interrupt Flag Counter</b><br>The register sets the count number which defines how many times of EPWM_CHn period occurs to set bit IFAIFn to request the EPWM period interrupt.<br>EPWM flag will be set in every IFACNT[15:0] times of EPWM period. |

**EPWM Accumulator Interrupt Flag Register (EPWM\_AINTSTS)**

| Register     | Offset         | R/W | Description                              |  |  |  | Reset Value |
|--------------|----------------|-----|------------------------------------------|--|--|--|-------------|
| EPWM_AINTSTS | EPWMx_BA+0x150 | R/W | EPWM Accumulator Interrupt Flag Register |  |  |  | 0x0000_0000 |

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

| Bits            | Description        |                                                                                                                                                                                                    |
|-----------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved           | Reserved.                                                                                                                                                                                          |
| [n]<br>n=0,1..5 | IIFAI <sub>n</sub> | <b>EPWM_CH<sub>n</sub> Interrupt Flag Accumulator Interrupt Flag</b><br>Flag is set by hardware when condition match IFASEL in EPWM_IFAn register, software can clear this bit by writing 1 to it. |

**EPWM Accumulator Interrupt Enable Register (EPWM\_AINTEN)**

| Register        | Offset         | R/W | Description                                | Reset Value |
|-----------------|----------------|-----|--------------------------------------------|-------------|
| EPWM_AINTE<br>N | EPWMx_BA+0x154 | R/W | EPWM Accumulator 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 |    | IFAIEN5 | IFAIEN4 | IFAIEN3 | IFAIEN2 | IFAIEN1 | IFAIEN0 |

| Bits            | Description |                                                                                                                                                                             |
|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                   |
| [n]<br>n=0,1..5 | IFAIENn     | <b>EPWM_CHn Interrupt Flag Accumulator Interrupt Enable Bits</b><br>0 = Interrupt Flag accumulator interrupt Disabled.<br>1 = Interrupt Flag accumulator interrupt Enabled. |

**EPWM Accumulator PDMA Control Register (EPWM\_APDMACTL)**

| Register      | Offset         | R/W | Description                            |  |  |  | Reset Value |
|---------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| EPWM_APDMACTL | EPWMx_BA+0x158 | R/W | EPWM Accumulator 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 |    | APDMAEN5 | APDMAEN4 | APDMAEN3 | APDMAEN2 | APDMAEN1 | APDMAEN0 |

| Bits            | Description |                                                                                                                                                                                                      |
|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                                            |
| [n]<br>n=0,1..5 | APDMAENn    | <b>Channel N Accumulator PDMA Enable Bits</b><br>0 = Channel n PDMA function Disabled.<br>1 = Channel n PDMA function Enabled for the channel n to trigger PDMA to transfer memory data to register. |

**EPWM Capture Input Enable Register (EPWM\_CAPINEN)**

| Register         | Offset         | R/W | Description                        | Reset Value |
|------------------|----------------|-----|------------------------------------|-------------|
| EPWM_CAPI<br>NEN | EPWMx_BA+0x200 | R/W | EPWM Capture Input Enable Register | 0x0000_0000 |

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

| Bits            | Description          |                                                                                                                                                                                                                                                                                                           |
|-----------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                 |
| [n]<br>n=0,1..5 | CAPINEN <sub>n</sub> | <p><b>Capture Input Enable Bits</b></p> <p>0 = EPWM Channel capture input path Disabled. The input of EPWM channel capture function is always regarded as 0.</p> <p>1 = EPWM Channel capture input path Enabled. The input of EPWM channel capture function comes from correlative multifunction pin.</p> |

**EPWM Capture Control Register (EPWM\_CAPCTL)**

| Register    | Offset         | R/W | Description                   |  |  |  | Reset Value |
|-------------|----------------|-----|-------------------------------|--|--|--|-------------|
| EPWM_CAPCTL | EPWMx_BA+0x204 | R/W | EPWM Capture Control Register |  |  |  | 0x0000_0000 |

|          |    |          |          |          |          |          |          |
|----------|----|----------|----------|----------|----------|----------|----------|
| 31       | 30 | 29       | 28       | 27       | 26       | 25       | 24       |
| Reserved |    | FCRLDEN5 | FCRLDEN4 | FCRLDEN3 | FCRLDEN2 | FCRLDEN1 | FCRLDEN0 |
| 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
| 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+n]<br>n=0,1..5 | FCRLDENn    | <b>Falling Capture Reload Enable Bits</b><br>0 = Falling capture reload counter Disabled.<br>1 = Falling capture reload counter Enabled.                                                                                                                                                                          |
| [23:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [16+n]<br>n=0,1..5 | RCRLDENn    | <b>Rising Capture Reload Enable Bits</b><br>0 = Rising capture reload counter Disabled.<br>1 = Rising capture reload counter Enabled.                                                                                                                                                                             |
| [15:14]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [8+n]<br>n=0,1..5  | CAPINVn     | <b>Capture Inverter Enable Bits</b><br>0 = Capture source inverter Disabled.<br>1 = Capture source inverter Enabled. Reverse the input signal from GPIO.                                                                                                                                                          |
| [7:6]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [n]<br>n=0,1..5    | CAPENn      | <b>Capture Function Enable Bits</b><br>0 = Capture function Disabled. RCAPDAT/FCAPDAT register will not be updated.<br>1 = Capture function Enabled. Capture latched the EPWM counter value when detected rising or falling edge of input signal and saved to RCAPDAT (Rising latch) and FCAPDAT (Falling latch). |

**EPWM Capture Status Register (EPWM\_CAPSTS)**

| Register     | Offset         | R/W | Description                  | Reset Value |
|--------------|----------------|-----|------------------------------|-------------|
| EPWM_CAPS_TS | EPWMx_BA+0x208 | R   | EPWM Capture 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 |    | 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.                                                                                                                                                                                                                                              |
| [8+n]<br>n=0,1..5 | CFLIFOVn    | <b>Capture Falling Latch Interrupt Flag Overrun Status (Read Only)</b><br>This flag indicates if falling latch happened when the corresponding CFLIF is 1.<br><b>Note:</b> This bit will be cleared automatically when user clear corresponding CFLIF. |
| [7:6]             | Reserved    | Reserved.                                                                                                                                                                                                                                              |
| [n]<br>n=0,1..5   | CRLIFOVn    | <b>Capture Rising Latch Interrupt Flag Overrun Status (Read Only)</b><br>This flag indicates if rising latch happened when the corresponding CRLIF is 1.<br><b>Note:</b> This bit will be cleared automatically when user clear corresponding CRLIF.   |

**EPWM Rising Capture Data Register 0~5 (EPWM\_RCAPDAT 0~5)**

| Register      | Offset         | R/W | Description                         | Reset Value |
|---------------|----------------|-----|-------------------------------------|-------------|
| EPWM_RCAPDAT0 | EPWMx_BA+0x20C | R   | EPWM Rising Capture Data Register 0 | 0x0000_0000 |
| EPWM_RCAPDAT1 | EPWMx_BA+0x214 | R   | EPWM Rising Capture Data Register 1 | 0x0000_0000 |
| EPWM_RCAPDAT2 | EPWMx_BA+0x21C | R   | EPWM Rising Capture Data Register 2 | 0x0000_0000 |
| EPWM_RCAPDAT3 | EPWMx_BA+0x224 | R   | EPWM Rising Capture Data Register 3 | 0x0000_0000 |
| EPWM_RCAPDAT4 | EPWMx_BA+0x22C | R   | EPWM Rising Capture Data Register 4 | 0x0000_0000 |
| EPWM_RCAPDAT5 | EPWMx_BA+0x234 | R   | EPWM Rising Capture Data Register 5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                        |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                              |
| [15:0]  | RCAPDAT     | <b>EPWM Rising Capture Data Register (Read Only)</b><br>When rising capture condition happened, the EPWM counter value will be saved in this register. |

**EPWM Falling Capture Data Register 0~5 (EPWM\_FCAPDAT 0~5)**

| Register      | Offset         | R/W | Description                          | Reset Value |
|---------------|----------------|-----|--------------------------------------|-------------|
| EPWM_FCAPDAT0 | EPWMx_BA+0x210 | R   | EPWM Falling Capture Data Register 0 | 0x0000_0000 |
| EPWM_FCAPDAT1 | EPWMx_BA+0x218 | R   | EPWM Falling Capture Data Register 1 | 0x0000_0000 |
| EPWM_FCAPDAT2 | EPWMx_BA+0x220 | R   | EPWM Falling Capture Data Register 2 | 0x0000_0000 |
| EPWM_FCAPDAT3 | EPWMx_BA+0x228 | R   | EPWM Falling Capture Data Register 3 | 0x0000_0000 |
| EPWM_FCAPDAT4 | EPWMx_BA+0x230 | R   | EPWM Falling Capture Data Register 4 | 0x0000_0000 |
| EPWM_FCAPDAT5 | EPWMx_BA+0x238 | R   | EPWM Falling Capture Data Register 5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                |
| [15:0]  | FCAPDAT     | <b>EPWM Falling Capture Data Register (Read Only)</b><br>When falling capture condition happened, the EPWM counter value will be saved in this register. |

**EPWM PDMA Control Register (EPWM\_PDMACTL)**

| Register      | Offset         | R/W | Description                |  |  |  | Reset Value |
|---------------|----------------|-----|----------------------------|--|--|--|-------------|
| EPWM_PDMA_CTL | EPWMx_BA+0x23C | R/W | EPWM PDMA Control Register |  |  |  | 0x0000_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 |    |    | CHSEL0_1 | CAPORD0_1 | CAPMOD0_1 |    | CHENO_1 |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                        |
| [20]    | CHSEL4_5    | Select Channel 4/5 to Do PDMA Transfer<br>0 = Channel4.<br>1 = Channel5.                                                                                                                                                                                                                                                         |
| [19]    | CAPORD4_5   | Capture Channel 4/5 Rising/Falling Order<br>Set this bit to determine whether the EPWM_RCAPDAT4/5 or EPWM_FCAPDAT4/5 is the first captured data transferred to memory through PDMA when CAPMOD4_5 =11.<br>0 = EPWM_FCAPDAT4/5 is the first captured data to memory.<br>1 = EPWM_RCAPDAT4/5 is the first captured data to memory. |
| [18:17] | CAPMOD4_5   | Select EPWM_RCAPDAT4/5 or EPWM_FCAPDAT4/5 to Do PDMA Transfer<br>00 = Reserved.<br>01 = EPWM_RCAPDAT4/5.<br>10 = EPWM_FCAPDAT4/5.<br>11 = Both EPWM_RCAPDAT4/5 and EPWM_FCAPDAT4/5.                                                                                                                                              |
| [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<br>0 = Channel2.<br>1 = Channel3.                                                                                                                                                                                                                                                         |
| [11]    | CAPORD2_3   | Capture Channel 2/3 Rising/Falling Order<br>Set this bit to determine whether the EPWM_RCAPDAT2/3 or EPWM_FCAPDAT2/3 is the first captured data transferred to memory through PDMA when CAPMOD2_3                                                                                                                                |

|        |           |                                                                                                                                                                                                                                                                                                                                         |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |           | =11.<br>0 = EPWM_FCAPDAT2/3 is the first captured data to memory.<br>1 = EPWM_RCAPDAT2/3 is the first captured data to memory.                                                                                                                                                                                                          |
| [10:9] | CAPMOD2_3 | <b>Select EPWM_RCAPDAT2/3 or EPWM_FCAODAT2/3 to Do PDMA Transfer</b><br>00 = Reserved.<br>01 = EPWM_RCAPDAT2/3.<br>10 = EPWM_FCAPDAT2/3.<br>11 = Both EPWM_RCAPDAT2/3 and EPWM_FCAPDAT2/3.                                                                                                                                              |
| [8]    | CHEN2_3   | <b>Channel 2/3 PDMA Enable Bit</b><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]    | CHSEL0_1  | <b>Select Channel 0/1 to Do PDMA Transfer</b><br>0 = Channel0.<br>1 = Channel1.                                                                                                                                                                                                                                                         |
| [3]    | CAPORD0_1 | <b>Capture Channel 0/1 Rising/Falling Order</b><br>Set this bit to determine whether the EPWM_RCAPDAT0/1 or EPWM_FCAPDAT0/1 is the first captured data transferred to memory through PDMA when CAPMOD0_1 =11.<br>0 = EPWM_FCAPDAT0/1 is the first captured data to memory.<br>1 = EPWM_RCAPDAT0/1 is the first captured data to memory. |
| [2:1]  | CAPMOD0_1 | <b>Select EPWM_RCAPDAT0/1 or EPWM_FCAPDAT0/1 to Do PDMA Transfer</b><br>00 = Reserved.<br>01 = EPWM_RCAPDAT0/1.<br>10 = EPWM_FCAPDAT0/1.<br>11 = Both EPWM_RCAPDAT0/1 and EPWM_FCAPDAT0/1.                                                                                                                                              |
| [0]    | CHENO_1   | <b>Channel 0/1 PDMA Enable Bit</b><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.                                                                                                                                                        |

**EPWM Capture Channel 0\_1, 2\_3, 4\_5 PDMA Register (EPWM\_PDMACAP\_0\_1, 2\_3, 4\_5)**

| Register         | Offset         | R/W | Description                           | Reset Value |
|------------------|----------------|-----|---------------------------------------|-------------|
| EPWM_PDMA_CAP0_1 | EPWMx_BA+0x240 | R   | EPWM Capture Channel 01 PDMA Register | 0x0000_0000 |
| EPWM_PDMA_CAP2_3 | EPWMx_BA+0x244 | R   | EPWM Capture Channel 23 PDMA Register | 0x0000_0000 |
| EPWM_PDMA_CAP4_5 | EPWMx_BA+0x248 | R   | EPWM Capture Channel 45 PDMA Register | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                       |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                             |
| [15:0]  | CAPBUF      | <b>EPWM Capture PDMA Register (Read Only)</b><br>This register is used as a buffer to transfer EPWM capture rising or falling data to memory by PDMA. |

**EPWM Capture Interrupt Enable Register (EPWM\_CAPIEN)**

| Register    | Offset         | R/W | Description                            |  |  |  | Reset Value |
|-------------|----------------|-----|----------------------------------------|--|--|--|-------------|
| EPWM_CAPIEN | EPWMx_BA+0x250 | R/W | EPWM Capture 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 |    | CAPFIEN5 | CAPFIEN4 | CAPFIEN3 | CAPFIEN2 | CAPFIEN1 | CAPFIENO |
| 7        | 6  | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved |    | CAPRIEN5 | CAPRIEN4 | CAPRIEN3 | CAPRIEN2 | CAPRIEN1 | CAPRIENO |

| Bits              | Description |                                                                                                                                                                    |
|-------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14]           | Reserved    | Reserved.                                                                                                                                                          |
| [8+n]<br>n=0,1..5 | CAPFIENn    | <b>EPWM Capture Falling Latch Interrupt Enable Bits</b><br>0 = Capture falling edge latch interrupt Disabled.<br>1 = Capture falling edge latch interrupt Enabled. |
| [7:6]             | Reserved    | Reserved.                                                                                                                                                          |
| [n]<br>n=0,1..5   | CAPRIENn    | <b>EPWM Capture Rising Latch Interrupt Enable Bits</b><br>0 = Capture rising edge latch interrupt Disabled.<br>1 = Capture rising edge latch interrupt Enabled.    |

**EPWM Capture Interrupt Flag Register (EPWM\_CAPIF)**

| Register   | Offset         | R/W | Description                          |  |  |  | Reset Value |
|------------|----------------|-----|--------------------------------------|--|--|--|-------------|
| EPWM_CAPIF | EPWMx_BA+0x254 | R/W | EPWM Capture Interrupt 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 |    | 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]           | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [8+n]<br>n=0,1..5 | <b>CFLIFn</b>   | <p><b>EPWM Capture Falling Latch Interrupt Flag</b><br/>           0 = No capture falling latch condition happened.<br/>           1 = Capture falling latch condition happened, this flag will be set to high.<br/> <b>Note1:</b> When Capture with PDMA operating, CAPIF corresponding channel CFLIF will be cleared by hardware after PDMA transfer data.<br/> <b>Note2:</b> This bit is cleared by writing 1 to it.</p> |
| [7:6]             | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [n]<br>n=0,1..5   | <b>CRLIFn</b>   | <p><b>EPWM Capture Rising Latch Interrupt Flag</b><br/>           0 = No capture rising latch condition happened.<br/>           1 = Capture rising latch condition happened, this flag will be set to high.<br/> <b>Note1:</b> When Capture with PDMA operating, CAPIF corresponding channel CRLIF will be cleared by hardware after PDMA transfer data.<br/> <b>Note2:</b> This bit is cleared by writing 1 to it.</p>    |

**EPWM Period Register Buffer 0~5 (EPWM\_PBUF0~5)**

| Register   | Offset         | R/W | Description         | Reset Value |
|------------|----------------|-----|---------------------|-------------|
| EPWM_PBUF0 | EPWMx_BA+0x304 | R   | EPWM PERIOD0 Buffer | 0x0000_0000 |
| EPWM_PBUF1 | EPWMx_BA+0x308 | R   | EPWM PERIOD1 Buffer | 0x0000_0000 |
| EPWM_PBUF2 | EPWMx_BA+0x30C | R   | EPWM PERIOD2 Buffer | 0x0000_0000 |
| EPWM_PBUF3 | EPWMx_BA+0x310 | R   | EPWM PERIOD3 Buffer | 0x0000_0000 |
| EPWM_PBUF4 | EPWMx_BA+0x314 | R   | EPWM PERIOD4 Buffer | 0x0000_0000 |
| EPWM_PBUF5 | EPWMx_BA+0x318 | R   | EPWM PERIOD5 Buffer | 0x0000_0000 |



| Bits    | Description |                                                                                   |
|---------|-------------|-----------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                         |
| [15:0]  | PBUF        | <b>EPWM Period Register Buffer (Read Only)</b><br>Used as PERIOD active register. |

**EPWM Comparator Register Buffer 0~5 (EPWM\_CMPBUF0~5)**

| Register         | Offset         | R/W | Description         | Reset Value |
|------------------|----------------|-----|---------------------|-------------|
| EPWM_CMPB<br>UF0 | EPWMx_BA+0x31C | R   | EPWM CMPDAT0 Buffer | 0x0000_0000 |
| EPWM_CMPB<br>UF1 | EPWMx_BA+0x320 | R   | EPWM CMPDAT1 Buffer | 0x0000_0000 |
| EPWM_CMPB<br>UF2 | EPWMx_BA+0x324 | R   | EPWM CMPDAT2 Buffer | 0x0000_0000 |
| EPWM_CMPB<br>UF3 | EPWMx_BA+0x328 | R   | EPWM CMPDAT3 Buffer | 0x0000_0000 |
| EPWM_CMPB<br>UF4 | EPWMx_BA+0x32C | R   | EPWM CMPDAT4 Buffer | 0x0000_0000 |
| EPWM_CMPB<br>UF5 | EPWMx_BA+0x330 | R   | EPWM CMPDAT5 Buffer | 0x0000_0000 |



| Bits    | Description |                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                          |
| [15:0]  | CMPBUF      | <b>EPWM Comparator Register Buffer (Read Only)</b><br>Used as CMP active register. |

**EPWM CLKPSC Buffer 0\_1, 2\_3, 4\_5 (EPWM\_CPSBUF0\_1, 2\_3, 4\_5)**

| Register       | Offset         | R/W | Description           | Reset Value |
|----------------|----------------|-----|-----------------------|-------------|
| EPWM_CPSBUF0_1 | EPWMx_BA+0x334 | R   | EPWM CLKPSC0_1 Buffer | 0x0000_0000 |
| EPWM_CPSBUF2_3 | EPWMx_BA+0x338 | R   | EPWM CLKPSC2_3 Buffer | 0x0000_0000 |
| EPWM_CPSBUF4_5 | EPWMx_BA+0x33C | R   | EPWM CLKPSC4_5 Buffer | 0x0000_0000 |

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

| Bits    | Description |                                                                                                    |
|---------|-------------|----------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                          |
| [11:0]  | CPSCBUF     | <b>EPWM Counter Clock Prescale Buffer</b><br>Used as EPWM counter clock pre-scale active register. |

EPWM FTCMPDAT Buffer (EPWM\_FTCBUF0\_1,2,3,4,5)

| Register        | Offset         | R/W | Description             |  |  |  | Reset Value |
|-----------------|----------------|-----|-------------------------|--|--|--|-------------|
| EPWM_FTCB_UF0_1 | EPWMx_BA+0x340 | R   | EPWM FTCMPDAT0_1 Buffer |  |  |  | 0x0000_0000 |
| EPWM_FTCB_UF2_3 | EPWMx_BA+0x344 | R   | EPWM FTCMPDAT2_3 Buffer |  |  |  | 0x0000_0000 |
| EPWM_FTCB_UF4_5 | EPWMx_BA+0x348 | R   | EPWM FTCMPDAT4_5 Buffer |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                       |
|---------|-------------|-----------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                             |
| [15:0]  | FTCMPBUF    | EPWM FTCMPDAT Buffer (Read Only)<br>Used as FTCMPDAT active register. |

**EPWM FTCMPDAT Indicator Register (EPWM\_FTCI)**

| Register  | Offset         | R/W | Description                      |  |  |  | Reset Value |
|-----------|----------------|-----|----------------------------------|--|--|--|-------------|
| EPWM_FTCI | EPWMx_BA+0x34C | R/W | EPWM FTCMPDAT Indicator Register |  |  |  | 0x0000_0000 |

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

| Bits               | Description     |                                                                                                                                                                            |
|--------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11]            | <b>Reserved</b> | Reserved.                                                                                                                                                                  |
| [8+n/2]<br>n=0,2,4 | <b>FTCMDn</b>   | <b>EPWM FTCMPDAT Down Indicator</b><br>Indicator is set by hardware when EPWM counter down count and reaches EPWM_FTCDATn, software can clear this bit by writing 1 to it. |
| [7:3]              | <b>Reserved</b> | Reserved.                                                                                                                                                                  |
| [n/2]<br>n=0,2,4   | <b>FTCMUn</b>   | <b>EPWM FTCMPDAT Up Indicator</b><br>Indicator is set by hardware when EPWM counter up count and reaches EPWM_FTCDATn, software can clear this bit by writing 1 to it.     |

## 6.12 Basic PWM Generator and Capture Timer (BPWM)

### 6.12.1 Overview

The chip provides two BPWM generators — BPWM0 and BPWM1 as shown in Figure 6.12-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.12.2 Features

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

### 6.12.3 Block Diagram



Figure 6.12-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.12-2 by ECLKSRC0 (BPWM\_CLKSRC[2:0]) for BPWM\_CLK0. In general case, BPWM0 Clock must be selected from PCLK0 by setting BPWM0SEL (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.12-3, and Table 6.12-1 BPWM Clock Source Control Registers Setting Table. BPWM0 and BPWM1 Clock must be selected to PLL clock by setting BPWM0SEL (CLK\_CLKSEL2[8]) and BPWM1SEL (CLK\_CLKSEL2[9]) to 0.



Figure 6.12-2 BPWM Clock Source Control



Figure 6.12-3 BPWM Clock Source Control

| Frequency Ratio<br>PCLK:BPWM<br>Clock | HCLK  | PCLK  | BPWM<br>Clock | HCLKSEL<br>CLK_CLKSEL0[2:0] | HCLKDIV<br>CLK_CLKDIV0[3:0] | APBnDIV<br>(CLK_CLKDIVn<br>[2+4n:4n]),<br>N Denotes 0 Or 1 | BPWMnSEL<br>(CLK_CLKSEL2[<br>N+8]),<br>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 BPWM Clock Source Control Registers Setting Table

Figure 6.12-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 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.12-4 BPWM Independent Mode Architecture Diagram

### 6.12.4 Basic Configuration

#### 6.12.4.1 BPWM0 Basic Configuration

- Clock Source Configuration
  - Select the source of BPWM0 peripheral clock on BPWM0SEL (CLK\_CLKSEL2[8]).
  - Enable BPWM0 peripheral clock in BPWM0CKEN (CLK\_APBCLK1[18]).
- Reset Configuration
  - Reset BPWM0 controller in BPWM0RST (SYS\_IPRST2[18]).
- Pin Configuration

| Group | Pin Name  | GPIO        | MFP   |
|-------|-----------|-------------|-------|
| BPWM0 | BPWM0_CH0 | PA.11       | MFP9  |
|       |           | PA.0, PG.14 | MFP12 |
|       |           | PE.2        | MFP13 |
|       | BPWM0_CH1 | PA.10       | MFP9  |
|       |           | PA.1, PG.13 | MFP12 |
|       |           | PE.3        | MFP13 |
|       | BPWM0_CH2 | PA.9        | MFP9  |
|       |           | PA.2, PG.12 | MFP12 |
|       |           | PE.4        | MFP13 |
|       | BPWM0_CH3 | PA.8        | MFP9  |
|       |           | PA.3, PG.11 | MFP12 |
|       |           | PE.5        | MFP13 |
|       | BPWM0_CH4 | PF.5        | MFP8  |
|       |           | PC.13       | MFP9  |
|       |           | PA.4, PG.10 | MFP12 |
|       |           | PE.6        | MFP13 |
|       | BPWM0_CH5 | PF.4        | MFP8  |
|       |           | PD.12       | MFP9  |
|       |           | PA.5, PG.9  | MFP12 |
|       |           | PE.7        | MFP13 |

#### 6.12.4.2 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]).
- Pin Configuration

| Group | Pin Name  | GPIO       | MFP   |
|-------|-----------|------------|-------|
| BPWM1 | BPWM1_CH0 | PB.11      | MFP10 |
|       |           | PF.3       | MFP11 |
|       |           | PC.7, PF.0 | MFP12 |
|       | BPWM1_CH1 | PB.10      | MFP10 |
|       |           | PF.2       | MFP11 |
|       |           | PC.6, PF.1 | MFP12 |
|       | BPWM1_CH2 | PB.9       | MFP10 |
|       |           | PA.12      | MFP11 |
|       |           | PA.7       | MFP12 |
|       | BPWM1_CH3 | PB.8       | MFP10 |
|       |           | PA.13      | MFP11 |
|       |           | PA.6       | MFP12 |
|       | BPWM1_CH4 | PB.7       | MFP10 |
|       |           | PA.14      | MFP11 |
|       |           | PC.8       | MFP12 |
|       | BPWM1_CH5 | PB.6       | MFP10 |
|       |           | PA.15      | MFP11 |
|       |           | PE.13      | MFP12 |

### 6.12.5 Functional Description

#### 6.12.5.1 BPWM Prescaler

The BPWM prescaler is used to divide clock source, prescaler counting CLKPSC +1 times, and BPWM counter only count once. The prescale is set by CLKPSC (BPWM\_CLKPSC[11:0]). Figure 6.12-5 shows an example of BPWM channel 0 CLKPSC waveform. The prescale counter will reload CLKPSC at the begin of the next prescale counter down-count.



Figure 6.12-5 BPWM\_CH0 CLKPSC waveform

#### 6.12.5.2 BPWM Counter

BPWM has one counter, and supports 3 counter types operation: Up Counter, Down Counter and Up-

### Down Counter types.

For BPWM channel0, CNT(BPWM\_CNT[15:0]) can clear to 0x00 by CNTCLR0 (BPWM\_CNTCLR[0]) when prescale counter down count to 0, and CNTCLR0(BPWM\_CNTCLR[0]) will be set 0 by hardware automatically.



Figure 6.12-6 BPWM Counter Clear waveform

### 6.12.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 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 = (PERIOD+1) \* (CLKPSC+1) \* BPWMx\_CLK clock time, as shown in Figure 6.12-7.



Figure 6.12-7 BPWM Up Counter Type

### 6.12.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 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, as shown in Figure 6.12-8.



Figure 6.12-8 BPWM Down Counter Type

#### 6.12.5.5 Up-Down Counter Type

In the up-down counter operation, the 16 bits BPWM counter is an up-down counter and starts counting-up 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 \times \text{PERIOD}) * (\text{CLKPSC} + 1) * \text{BPWMx\_CLK}$  clock time, as shown in Figure 6.12-9. The DIRF (BPWM\_CNT[16]) is counter direction indicator flag, where high is up counting, and low is down counting.



**Note:** When in up-down count type, period interrupt flag occurs at center point event.

Figure 6.12-9 BPWM Up-Down Counter Type

#### 6.12.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 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.12-10.



Figure 6.12-10 BPWM CMPDAT Events in Up-Down Counter Type

#### 6.12.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.12-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.12-11. User can know the PERIOD and CMPDAT update condition, by watching BPWM period and CMU 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-11 Period Loading Mode with Up-Counter Type

#### 6.12.5.8 Immediately Loading Mode

If the IMMLDEN<sub>n</sub> (BPWM\_CTL0[21:16]) bit which corresponds to BPWM channel <sub>n</sub> 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 CNTMAX0(BPWM\_STATUS[0]) will raise, and then counter will count wraparound. Immediately loading mode has the highest priority. If IMMLDEN<sub>n</sub> has been set, other loading mode for channel <sub>n</sub> will become invalid. Figure 6.12-12 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-12 Immediately Loading Mode with Up-Counter Type

#### 6.12.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 up-down 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.12-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.12-13 Center Loading Mode with Up-Down-Counter Type

#### 6.12.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\_WGCTL0 and BPWM\_WGCTL1 registers. Using these points can easily generate asymmetric BPWM pulse or variant waveform as shown in Figure 6.12-14. In the figure, there is a comparator n to generate BPWM pulse, whrer 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.12-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 1.1-1), down counter type (Table 1.1-2) and up-down counter type (Table 1.1-3). By using event priority, user can easily generate 0% to 100% duty pulse as shown in Figure 6.12-15.



Figure 6.12-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.12-2 BPWM Pulse Generation Event Priority for Up-Counter

| Priority    | Down Event           |
|-------------|----------------------|
| 1 (Highest) | Zero event (CNT = 0) |

|            |                                  |
|------------|----------------------------------|
| 2          | Compare down event (CNT = CMPDn) |
| 3 (Lowest) | Period event (CNT = PERIOD)      |

Table 6.12-3 BPWM Pulse Generation Event Priority for Down-Counter

| Priority    | Up Event                       | Down Event                           |
|-------------|--------------------------------|--------------------------------------|
| 1 (Highest) | Compare up event (CNT = CMPUn) | Compare down event (CNT = CMPDn)     |
| 2           | Zero event (CNT = 0)           | Period (center) event (CNT = PERIOD) |

Table 6.12-4 BPWM Pulse Generation Event Priority for Up-Down-Counter

#### 6.12.5.11 Synchronous function

To start BPWM and PWM counters in the same time, user have 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.12.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.12-16.



Figure 6.12-16 BPWM\_CH0 Output Control 3 Steps

#### 6.12.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]) determine the state of the BPWM channel output when the channel is masked via the MSKDAT bits. Figure 6.12-17 shows an example of how BPWM mask control can be used for the override feature.



Figure 6.12-17 Mask Control Waveform Illustration

#### 6.12.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.12-18 shows the initial state before BPWM starts with different polarity settings.



Figure 6.12-18 Initial State and Polarity Control

### 6.12.5.15 BPWM Interrupt Generator

There are two independent interrupts for each BPWM as shown in Figure 6.12-19.

BPWM interrupt (BPWM\_INT) comes from BPWM complementary pair events. The counter can generate the Zero point Interrupt Flag ZIF0 (BPWM\_INTSTS0[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\_INTSTS0[21:16]) is set and if matching at the opposite direction, the Down Interrupt Flag CMPDIFn (BPWM\_INTSTS0[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.12-19 demonstrates the architecture of the BPWM interrupts.



Figure 6.12-19 BPWM\_CH0 and BPWM\_CH1 Pair Interrupt Architecture Diagram

### 6.12.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 TRGSEL0, TRGSEL1, ..., and TRGSEL5, which are located in BPWM\_EADCTS0[3:0], BPWM\_EADCTS0[11:8], BPWM\_EADCTS0[19:16], BPWM\_EADCTS0[27:24], BPWM\_EADCTS1[3:0] and BPWM\_EADCTS1[11:8], respectively. Setting TRGENn is to enable the trigger output to EADC, where TRGENn is TRGEN0, TRGEN1, ..., TRGEN5, which are located in BPWM\_EADCTS0[7], BPWM\_EADCTS0[15], BPWM\_EADCTS0[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.12-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.12-22 is the trigger EADC timing waveform in the up-down counter type.



Figure 6.12-20 BPWM\_CH0 and BPWM\_CH1 Pair Trigger EADC Source Block Diagram



Figure 6.12-21 BPWM CH0~ CH5 Trigger EADC Block Diagram



Figure 6.12-22 BPWM Trigger EADC in Up-Down Counter Type Timing Waveform

#### 6.12.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.12-23 is the capture block diagram of channel 0.



Figure 6.12-23 BPWM\_CH0 Capture Block Diagram

Figure 6.12-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\_RCAPDATn. 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.12-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 channel 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 CAPFIEn 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 CAPFI n (BPWM\_CAPIF[13:8]) and the Over run status CFIFOVn (BPWM\_CAPSTS[13:8]).



Figure 6.12-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 FCRLDEN<sub>n</sub> and RCRLDEN<sub>n</sub> bits of PWM\_CAPCTL register to 1.

For the negative pulse case, the channel low pulse width is calculated as  $(\text{BPWM\_PERIOD} + 1 - \text{BPWM\_RCAPDAT}_n)$  BPWM counter time, where one BPWM counter time is  $(\text{CLKPSC}+1) * \text{BPWMx\_CLK}$  clock time. In the case shown in Figure 6.12-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  $(\text{BPWM\_PERIOD} + 1 - \text{BPWM\_FCAPDAT}_n)$  BPWM counter time, where one BPWM counter time is  $(\text{CLKPSC}+1) * \text{BPWMx\_CLK}$  clock time. In the case shown in Figure 6.12-24, high pulse width is  $8+1-7 = 2$  BPWM counter time.

### 6.12.6 Register Map

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

| Register                      | Offset        | R/W | Description                  | Reset Value |
|-------------------------------|---------------|-----|------------------------------|-------------|
| <b>BPWM Base Address:</b>     |               |     |                              |             |
| <b>BPWM0_BA = 0x4005_A000</b> |               |     |                              |             |
| <b>BPWM1_BA = 0x4005_B000</b> |               |     |                              |             |
| <b>BPWM_CTL0</b><br>x=0, 1    | BPWMx_BA+0x00 | R/W | BPWM Control Register 0      | 0x0000_0000 |
| <b>BPWM_CTL1</b><br>x=0, 1    | BPWMx_BA+0x04 | R/W | BPWM Control Register 1      | 0x0000_0000 |
| <b>BPWM_CLKSRC</b><br>x=0, 1  | BPWMx_BA+0x10 | R/W | BPWM Clock Source Register   | 0x0000_0000 |
| <b>BPWM_CLKPSC</b><br>x=0, 1  | BPWMx_BA+0x14 | R/W | BPWM Clock Prescale Register | 0x0000_0000 |
| <b>BPWM_CNTEN</b><br>x=0, 1   | BPWMx_BA+0x20 | R/W | BPWM Counter Enable Register | 0x0000_0000 |
| <b>BPWM_CNTCLR</b><br>x=0, 1  | BPWMx_BA+0x24 | R/W | BPWM Clear Counter Register  | 0x0000_0000 |
| <b>BPWM_PERIOD</b><br>x=0, 1  | BPWMx_BA+0x30 | R/W | BPWM Period Register         | 0x0000_0000 |
| <b>BPWM_CMPDAT0</b><br>x=0, 1 | BPWMx_BA+0x50 | R/W | BPWM Comparator Register 0   | 0x0000_0000 |
| <b>BPWM_CMPDAT1</b><br>x=0, 1 | BPWMx_BA+0x54 | R/W | BPWM Comparator Register 1   | 0x0000_0000 |
| <b>BPWM_CMPDAT2</b><br>x=0, 1 | BPWMx_BA+0x58 | R/W | BPWM Comparator Register 2   | 0x0000_0000 |
| <b>BPWM_CMPDAT3</b><br>x=0, 1 | BPWMx_BA+0x5C | R/W | BPWM Comparator Register 3   | 0x0000_0000 |
| <b>BPWM_CMPDAT4</b><br>x=0, 1 | BPWMx_BA+0x60 | R/W | BPWM Comparator Register 4   | 0x0000_0000 |
| <b>BPWM_CMPDAT5</b><br>x=0, 1 | BPWMx_BA+0x64 | R/W | BPWM Comparator Register 5   | 0x0000_0000 |
| <b>BPWM_CNT</b><br>x=0, 1     | BPWMx_BA+0x90 | R   | BPWM Counter Register        | 0x0000_0000 |
| <b>BPWM_WGCTL0</b><br>x=0, 1  | BPWMx_BA+0xB0 | R/W | BPWM Generation Register 0   | 0x0000_0000 |
| <b>BPWM_WGCTL1</b><br>x=0, 1  | BPWMx_BA+0xB4 | R/W | BPWM Generation Register 1   | 0x0000_0000 |
| <b>BPWM_MSKEN</b><br>x=0, 1   | BPWMx_BA+0xB8 | R/W | BPWM Mask Enable Register    | 0x0000_0000 |
| <b>BPWM_MSK</b>               | BPWMx_BA+0xBC | R/W | BPWM Mask Data Register      | 0x0000_0000 |

|                                 |                |     |                                            |             |
|---------------------------------|----------------|-----|--------------------------------------------|-------------|
| x=0, 1                          |                |     |                                            |             |
| <b>BPWM_POLCTL</b><br>x=0, 1    | BPWMx_BA+0xD4  | R/W | BPWM Pin Polar Inverse Register            | 0x0000_0000 |
| <b>BPWM_POEN</b><br>x=0, 1      | BPWMx_BA+0xD8  | R/W | BPWM Output Enable Register                | 0x0000_0000 |
| <b>BPWM_INTEN</b><br>x=0, 1     | BPWMx_BA+0xE0  | R/W | BPWM Interrupt Enable Register             | 0x0000_0000 |
| <b>BPWM_INTSTS</b><br>x=0, 1    | BPWMx_BA+0xE8  | R/W | BPWM Interrupt Flag Register               | 0x0000_0000 |
| <b>BPWM_EADCTS0</b><br>x=0, 1   | BPWMx_BA+0xF8  | R/W | BPWM Trigger EADC Source Select Register 0 | 0x0000_0000 |
| <b>BPWM_EADCTS1</b><br>x=0, 1   | BPWMx_BA+0xFC  | R/W | BPWM Trigger EADC Source Select Register 1 | 0x0000_0000 |
| <b>BPWM_SSCTL</b><br>x=0, 1     | BPWMx_BA+0x110 | R/W | BPWM Synchronous Start Control Register    | 0x0000_0000 |
| <b>BPWM_SSTRG</b><br>x=0, 1     | BPWMx_BA+0x114 | W   | BPWM Synchronous Start Trigger Register    | 0x0000_0000 |
| <b>BPWM_STATUS</b><br>x=0, 1    | BPWMx_BA+0x120 | R/W | BPWM Status Register                       | 0x0000_0000 |
| <b>BPWM_CAPINEN</b><br>x=0, 1   | BPWMx_BA+0x200 | R/W | BPWM Capture Input Enable Register         | 0x0000_0000 |
| <b>BPWM_CAPCTL</b><br>x=0, 1    | BPWMx_BA+0x204 | R/W | BPWM Capture Control Register              | 0x0000_0000 |
| <b>BPWM_CAPSTS</b><br>x=0, 1    | BPWMx_BA+0x208 | R   | BPWM Capture Status Register               | 0x0000_0000 |
| <b>BPWM_RCAPDATA0</b><br>x=0, 1 | BPWMx_BA+0x20C | R   | BPWM Rising Capture Data Register 0        | 0x0000_0000 |
| <b>BPWM_FCAPDATA0</b><br>x=0, 1 | BPWMx_BA+0x210 | R   | BPWM Falling Capture Data Register 0       | 0x0000_0000 |
| <b>BPWM_RCAPDATA1</b><br>x=0, 1 | BPWMx_BA+0x214 | R   | BPWM Rising Capture Data Register 1        | 0x0000_0000 |
| <b>BPWM_FCAPDATA1</b><br>x=0, 1 | BPWMx_BA+0x218 | R   | BPWM Falling Capture Data Register 1       | 0x0000_0000 |
| <b>BPWM_RCAPDATA2</b><br>x=0, 1 | BPWMx_BA+0x21C | R   | BPWM Rising Capture Data Register 2        | 0x0000_0000 |
| <b>BPWM_FCAPDATA2</b><br>x=0, 1 | BPWMx_BA+0x220 | R   | BPWM Falling Capture Data Register 2       | 0x0000_0000 |
| <b>BPWM_RCAPDATA3</b><br>x=0, 1 | BPWMx_BA+0x224 | R   | BPWM Rising Capture Data Register 3        | 0x0000_0000 |
| <b>BPWM_FCAPDATA3</b><br>x=0, 1 | BPWMx_BA+0x228 | R   | BPWM Falling Capture Data Register 3       | 0x0000_0000 |

|                                 |                |     |                                        |             |
|---------------------------------|----------------|-----|----------------------------------------|-------------|
| <b>BPWM_RCAPDAT4<br/>x=0, 1</b> | BPWMx_BA+0x22C | R   | BPWM Rising Capture Data Register 4    | 0x0000_0000 |
| <b>BPWM_FCAPDAT4<br/>x=0, 1</b> | BPWMx_BA+0x230 | R   | BPWM Falling Capture Data Register 4   | 0x0000_0000 |
| <b>BPWM_RCAPDAT5<br/>x=0, 1</b> | BPWMx_BA+0x234 | R   | BPWM Rising Capture Data Register 5    | 0x0000_0000 |
| <b>BPWM_FCAPDAT5<br/>x=0, 1</b> | BPWMx_BA+0x238 | R   | BPWM Falling Capture Data Register 5   | 0x0000_0000 |
| <b>BPWM_CAPIEN<br/>x=0, 1</b>   | BPWMx_BA+0x250 | R/W | BPWM Capture Interrupt Enable Register | 0x0000_0000 |
| <b>BPWM_CAPIF<br/>x=0, 1</b>    | BPWMx_BA+0x254 | R/W | BPWM Capture Interrupt Flag Register   | 0x0000_0000 |
| <b>BPWM_PBUF<br/>x=0, 1</b>     | BPWMx_BA+0x304 | R   | BPWM PERIOD Buffer                     | 0x0000_0000 |
| <b>BPWM_CMPBUF0<br/>x=0, 1</b>  | BPWMx_BA+0x31C | R   | BPWM CMPDAT 0 Buffer                   | 0x0000_0000 |
| <b>BPWM_CMPBUF1<br/>x=0, 1</b>  | BPWMx_BA+0x320 | R   | BPWM CMPDAT 1 Buffer                   | 0x0000_0000 |
| <b>BPWM_CMPBUF2<br/>x=0, 1</b>  | BPWMx_BA+0x324 | R   | BPWM CMPDAT 2 Buffer                   | 0x0000_0000 |
| <b>BPWM_CMPBUF3<br/>x=0, 1</b>  | BPWMx_BA+0x328 | R   | BPWM CMPDAT 3 Buffer                   | 0x0000_0000 |
| <b>BPWM_CMPBUF4<br/>x=0, 1</b>  | BPWMx_BA+0x32C | R   | BPWM CMPDAT 4 Buffer                   | 0x0000_0000 |
| <b>BPWM_CMPBUF5<br/>x=0, 1</b>  | BPWMx_BA+0x330 | R   | BPWM CMPDAT 5 Buffer                   | 0x0000_0000 |

### 6.12.7 Register Description

#### BPWM Control Register 0 (BPWM\_CTL0)

| Register  | Offset        | R/W | Description             |  |  |  | Reset Value |
|-----------|---------------|-----|-------------------------|--|--|--|-------------|
| BPWM_CTL0 | BPWMx_BA+0x00 | R/W | BPWM Control Register 0 |  |  |  | 0x0000_0000 |

|           |         |          |          |          |          |          |          |
|-----------|---------|----------|----------|----------|----------|----------|----------|
| 31        | 30      | 29       | 28       | 27       | 26       | 25       | 24       |
| DBGTRIOFF | DBGHALT | Reserved |          |          |          |          |          |
| 23        | 22      | 21       | 20       | 19       | 18       | 17       | 16       |
| Reserved  |         | IMMLDEN5 | IMMLDEN4 | IMMLDEN3 | IMMLDEN2 | IMMLDEN1 | IMMLDEN0 |
| 15        | 14      | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved  |         |          |          |          |          |          |          |
| 7         | 6       | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved  |         | CTRLD5   | CTRLD4   | CTRLD3   | CTRLD2   | CTRLD1   | CTRLD0   |

| Bits               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]               | <b>DBGTRIOFF</b><br><b>ICE Debug Mode Acknowledge Disable (Write Protect)</b><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><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                         |
| [30]               | <b>DBGHALT</b><br><b>ICE Debug Mode Counter Halt (Write Protect)</b><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><b>Note:</b> This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                      |
| [29:22]            | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [16+n]<br>n=0,1..5 | <b>IMMLDENn</b><br><b>Immediately Load Enable Bit(S)</b><br>Each bit n controls the corresponding BPWM channel n.<br>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><b>Note:</b> If IMMLDENn is Enabled, WINLDENn and CTRLDn will be invalid. |
| [15:6]             | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [n]<br>n=0,1..5    | <b>CTRLDn</b><br><b>Center Re-load</b><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 |  |  |  | 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 |    |    |    |    |    | <b>CNTTYPE0</b> |    |

| Bits   | Description     |                                                                                                                                                                                                                                                                             |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                   |
| [1:0]  | <b>CNTTYPE0</b> | <p><b>BPWM Counter Behavior Type 0</b></p> <p>Each bit n controls corresponding BPWM channel n.</p> <p>00 = Up counter type (supports in capture mode).</p> <p>01 = Down count type (supports in capture mode).</p> <p>10 = Up-down counter type.</p> <p>11 = Reserved.</p> |

**BPWM Clock Source Register (BPWM\_CLKSRC)**

| Register    | Offset        | R/W | Description                |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------|--|--|--|-------------|
| BPWM_CLKSRC | BPWMx_BA+0x10 | R/W | BPWM Clock Source 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 |    |    |    |    | ECLKSRC0 |    |    |

| Bits   | Description |                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                         |
| [2:0]  | ECLKSRC0    | <b>BPWM_CH01 External Clock Source Select</b><br>000 = BPWMx_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. |

**BPWM Clock Prescale Register (BPWM\_CLKPSC)**

| Register    | Offset        | R/W | Description                  |  |  |  | Reset Value |
|-------------|---------------|-----|------------------------------|--|--|--|-------------|
| BPWM_CLKPSC | BPWMx_BA+0x14 | R/W | BPWM Clock Prescale 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 |    |    |    | CLKPSC |    |    |    |
| 7        | 6  | 5  | 4  | 3      | 2  | 1  | 0  |
| CLKPSC   |    |    |    |        |    |    |    |

| Bits    | Description |                                                                                                                                                                                                           |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                 |
| [11:0]  | CLKPSC      | <b>BPWM Counter Clock Prescale</b><br>The clock of BPWM counter is decided by clock prescaler. Each BPWM pair share one 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 |  |  |  |  | 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 |    |    |    |    |    |    | CNTEN0 |

| Bits   | Description |                                                                                                                                               |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                     |
| [0]    | CNTEN0      | <b>BPWM Counter 0 Enable Bit</b><br>0 = BPWM Counter and clock prescaler stop running.<br>1 = BPWM Counter and clock prescaler start running. |

**BPWM Clear Counter Register (BPWM\_CNTCLR)**

| Register    | Offset        | R/W | Description                 |  |  |  | Reset Value |
|-------------|---------------|-----|-----------------------------|--|--|--|-------------|
| BPWM_CNTCLR | BPWMx_BA+0x24 | R/W | BPWM Clear Counter Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                        |
| [0]    | CNTCLR0     | <b>Clear BPWM Counter Control Bit 0</b><br>It is automatically cleared by hardware.<br>0 = No effect.<br>1 = Clear 16-bit BPWM counter to 0000H. |

**BPWM Period Register (BPWM\_PERIOD)**

| Register    | Offset        | R/W | Description          |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------|--|--|--|-------------|
| BPWM_PERIOD | BPWMx_BA+0x30 | R/W | BPWM 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      | <b>BPWM Period Register</b><br>Up-Count mode: In this mode, BPWM counter counts from 0 to PERIOD, and restarts from 0.<br>Down-Count mode: In this mode, BPWM counter counts from PERIOD to 0, and restarts from PERIOD.<br>$\text{BPWM period time} = (\text{PERIOD} + 1) * \text{BPWM\_CLK period.}$<br>Up-Down-Count mode: In this mode, BPWM counter counts from 0 to PERIOD, then decrements to 0 and repeats again.<br>$\text{BPWM period time} = 2 * \text{PERIOD} * \text{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 | 0x0000_0000 |
| BPWM_CMPDAT1 | BPWMx_BA+0x54 | R/W | BPWM Comparator Register 1 | 0x0000_0000 |
| BPWM_CMPDAT2 | BPWMx_BA+0x58 | R/W | BPWM Comparator Register 2 | 0x0000_0000 |
| BPWM_CMPDAT3 | BPWMx_BA+0x5C | R/W | BPWM Comparator Register 3 | 0x0000_0000 |
| BPWM_CMPDAT4 | BPWMx_BA+0x60 | R/W | BPWM Comparator Register 4 | 0x0000_0000 |
| BPWM_CMPDAT5 | BPWMx_BA+0x64 | R/W | BPWM Comparator Register 5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                      |
| [15:0]  | CMPDAT      | <b>BPWM Comparator Register</b><br>CMPDAT use to compare with CNTR to generate BPWM waveform, interrupt and trigger EADC.<br>In independent mode, CMPDAT0~5 denote as 6 independent BPWM_CH0~5 compared point. |

**BPWM Counter Register (BPWM\_CNT)**

| Register | Offset        | R/W | Description           |  |  |  | Reset Value |
|----------|---------------|-----|-----------------------|--|--|--|-------------|
| BPWM_CNT | BPWMx_BA+0x90 | R   | BPWM 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  |
| CNT      |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| CNT      |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                    |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                          |
| [16]    | DIRF        | <b>BPWM Direction Indicator Flag (Read Only)</b><br>0 = Counter is Down count.<br>1 = Counter is UP count.         |
| [15:0]  | CNT         | <b>BPWM Data Register (Read Only)</b><br>User can monitor CNTR to know the current value in 16-bit period counter. |

**BPWM Generation Register 0 (BPWM\_WGCTL0)**

| 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 |    | PRDPCTL0 |    |
| 15       | 14 | 13       | 12 | 11       | 10 | 9        | 8  |
| Reserved |    |          |    | ZPCTL5   |    | ZPCTL4   |    |
| 7        | 6  | 5        | 4  | 3        | 2  | 1        | 0  |
| ZPCTL3   |    | ZPCTL2   |    | ZPCTL1   |    | ZPCTL0   |    |

| Bits                        | Description          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28]                     | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [16+2n+1:16+2n]<br>n=0,1..5 | PRDPCTL <sub>n</sub> | <p><b>BPWM Period (Center) Point Control</b><br/>           Each bit n controls the corresponding BPWM channel n.<br/>           00 = Do nothing.<br/>           01 = BPWM period (center) point output Low.<br/>           10 = BPWM period (center) point output High.<br/>           11 = BPWM period (center) point output Toggle.<br/>           BPWM can control output level when BPWM counter count to (PERIOD+1).<br/> <b>Note:</b> This bit is center point control when BPWM counter operating in up-down counter type.</p> |
| [15:12]                     | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [2n+1:2n]<br>n=0,1..5       | ZPCTL <sub>n</sub>   | <p><b>BPWM Zero Point Control</b><br/>           Each bit n controls the corresponding BPWM channel n.<br/>           00 = Do nothing.<br/>           01 = BPWM zero point output Low.<br/>           10 = BPWM zero point output High.<br/>           11 = BPWM zero point output Toggle.<br/>           BPWM can control output level when BPWM counter count to zero.</p>                                                                                                                                                           |

**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 |    | CMPDCTL0 |    |
| 15       | 14 | 13       | 12 | 11       | 10 | 9        | 8  |
| Reserved |    |          |    | CMPUCTL5 |    | CMPUCTL4 |    |
| 7        | 6  | 5        | 4  | 3        | 2  | 1        | 0  |
| CMPUCTL3 |    | CMPUCTL2 |    | CMPUCTL1 |    | CMPUCTL0 |    |

| Bits                        | Description                |                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28]                     | <b>Reserved</b>            | Reserved.                                                                                                                                                                                                                                                                                                                                                  |
| [16+2n+1:16+2n]<br>n=0,1..5 | <b>CMPDCTL<sub>n</sub></b> | <p><b>BPWM Compare Down Point Control</b></p> <p>Each bit n controls the corresponding BPWM channel n.</p> <p>00 = Do nothing.<br/>01 = BPWM compare down point output Low.<br/>10 = BPWM compare down point output High.<br/>11 = BPWM compare down point output Toggle.</p> <p>BPWM can control output level when BPWM counter down count to CMPDAT.</p> |
| [15:12]                     | <b>Reserved</b>            | Reserved.                                                                                                                                                                                                                                                                                                                                                  |
| [2n+1:2n]<br>n=0,1..5       | <b>CMPUCTL<sub>n</sub></b> | <p><b>BPWM Compare Up Point Control</b></p> <p>Each bit n controls the corresponding BPWM channel n.</p> <p>00 = Do nothing.<br/>01 = BPWM compare up point output Low.<br/>10 = BPWM compare up point output High.<br/>11 = BPWM compare up point output Toggle.</p> <p>BPWM can control output level when BPWM counter up count to CMPDAT.</p>           |

**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.                                                                                                                                                                                                                                                                                                                                                        |
| [n]<br>n=0,1..5 | MSKENn      | <p><b>BPWM Mask Enable Bits</b></p> <p>Each bit n controls the corresponding BPWM channel n.</p> <p>The BPWM output signal will be masked when this bit is enabled. The corresponding BPWM channel n will output MSKDATn (BPWM_MSK[5:0]) data.</p> <p>0 = BPWM output signal is non-masked.</p> <p>1 = BPWM output signal is masked and output MSKDATn data.</p> |

**BPWM Mask DATA Register (BPWM\_MSK)**

| Register | Offset        | R/W | Description             |  |  |  | Reset Value |
|----------|---------------|-----|-------------------------|--|--|--|-------------|
| BPWM_MSK | BPWMx_BA+0xBC | R/W | BPWM Mask Data Register |  |  |  | 0x0000_0000 |

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

| Bits            | Description |                                                                                                                                                                                                                                                                            |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                  |
| [n]<br>n=0,1..5 | MSKDATn     | <p><b>BPWM Mask Data Bit</b></p> <p>This data bit control the state of BPWMn output pin, if corresponding mask function is enabled. Each bit n controls the corresponding BPWM channel n.</p> <p>0 = Output logic low to BPWMn.</p> <p>1 = Output logic high to BPWMn.</p> |

**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 | 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 |    | PINV5 | PINV4 | PINV3 | PINV2 | PINV1 | PINV0 |

| Bits            | Description |                                                                                                                                                                                                                                                          |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                                                                                                |
| [n]<br>n=0,1..5 | PINVn       | <p><b>BPWM PIN Polar Inverse Control</b></p> <p>The register controls polarity state of BPWM output. Each bit n controls the corresponding BPWM channel n.</p> <p>0 = BPWM output polar inverse Disabled.<br/>1 = BPWM output polar inverse Enabled.</p> |

**BPWM Output Enable Register (BPWM\_POEN)**

| Register  | Offset        | R/W | Description                 |  |  |  | Reset Value |
|-----------|---------------|-----|-----------------------------|--|--|--|-------------|
| BPWM_POEN | BPWMx_BA+0xD8 | R/W | BPWM Output Enable Register |  |  |  | 0x0000_0000 |

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

| Bits            | Description |                                                                                                                                                           |
|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                 |
| [n]<br>n=0,1..5 | POENn       | <b>BPWM Pin Output Enable Bits</b><br>Each bit n controls the corresponding BPWM channel n.<br>0 = 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 |  |  |  |  | 0x0000_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.                                                                                                                                                                                                 |
| [24+n]<br>n=0,1..5 | CMPDIENn    | <b>BPWM Compare Down Count Interrupt Enable Bits</b><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.                                                                                                                                                                                                 |
| [16+n]<br>n=0,1..5 | CMPUIENn    | <b>BPWM Compare Up Count Interrupt Enable Bits</b><br>Each bit n controls the corresponding BPWM channel n.<br>0 = Compare up count interrupt Disabled.<br>1 = Compare up count interrupt Enabled.        |
| [15:9]             | Reserved    | Reserved.                                                                                                                                                                                                 |
| [8]                | PIENO       | <b>BPWM Period Point Interrupt 0 Enable Bit</b><br>0 = Period point interrupt Disabled.<br>1 = Period point interrupt Enabled.<br><b>Note:</b> When up-down counter type period point means center point. |
| [7:1]              | Reserved    | Reserved.                                                                                                                                                                                                 |
| [0]                | ZIENO       | <b>BPWM Zero Point Interrupt 0 Enable Bit</b><br>0 = Zero point interrupt Disabled.<br>1 = Zero point interrupt Enabled.                                                                                  |

**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       |
| Reserved |    |         |         |         |         |         | PIFO    |
| 7        | 6  | 5       | 4       | 3       | 2       | 1       | 0       |
| Reserved |    |         |         |         |         |         | ZIFO    |

| Bits               | Description |                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                     |
| [24+n]<br>n=0,1..5 | CMPDIFn     | <p><b>BPWM Compare Down Count Interrupt Flag</b><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/> <b>Note:</b> If CMPDAT equal to PERIOD, this flag is not working in down counter type selection.</p> |
| [23:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                     |
| [16+n]<br>n=0,1..5 | CMPUIFn     | <p><b>BPWM Compare Up Count Interrupt Flag</b><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/> <b>Note:</b> If CMPDAT equal to PERIOD, this flag is not working in up counter type selection.</p>                      |
| [15:9]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                     |
| [8]                | PIFO        | <p><b>BPWM Period Point Interrupt Flag 0</b><br/>           This bit is set by hardware when BPWM_CH0 counter reaches BPWM_PERIOD0, software can write 1 to clear this bit to 0.</p>                                                                                                                                                                                          |
| [7:1]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                     |
| [0]                | ZIFO        | <p><b>BPWM Zero Point Interrupt Flag 0</b><br/>           This bit is set by hardware when BPWM_CH0 counter reaches 0, software can write 1 to clear this bit to 0.</p>                                                                                                                                                                                                       |

**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 |  |  |  | 0x0000_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  |
| TRGEN0 | Reserved |    |    |    | TRGSEL0 |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | TRGEN3      | BPWM_CH3 Trigger EADC Enable Bit                                                                                                                                                                                                                                                                                                                                                                                |
| [30:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                       |
| [27:24] | TRGSEL3     | <b>BPWM_CH3 Trigger EADC Source Select</b><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                                                                                                                                                                                                                                                                                                                                                                                |
| [22:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                       |
| [19:16] | TRGSEL2     | <b>BPWM_CH2 Trigger EADC Source Select</b><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.                                                                 |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 1001 = BPWM_CH3 down-count CMPDAT point.<br>Others reserved                                                                                                                                                                                                                                                                                                                                                    |
| [15]    | <b>TRGEN1</b>   | BPWM_CH1 Trigger EADC Enable Bit                                                                                                                                                                                                                                                                                                                                                                               |
| [14:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [11:8]  | <b>TRGSEL1</b>  | <b>BPWM_CH1 Trigger EADC Source Select</b><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]     | <b>TRGEN0</b>   | BPWM_CH0 Trigger EADC Enable Bit                                                                                                                                                                                                                                                                                                                                                                               |
| [6:4]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3:0]   | <b>TRGSEL0</b>  | <b>BPWM Trigger EADC Source Select</b><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     |

**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 |  |  |  | 0x0000_0000 |

|          |          |    |    |         |    |    |    |
|----------|----------|----|----|---------|----|----|----|
| 31       | 30       | 29 | 28 | 27      | 26 | 25 | 24 |
| Reserved |          |    |    |         |    |    |    |
| 23       | 22       | 21 | 20 | 19      | 18 | 17 | 16 |
| Reserved |          |    |    |         |    |    |    |
| 15       | 14       | 13 | 12 | 11      | 10 | 9  | 8  |
| TRGEN5   | Reserved |    |    | 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                                                                                                                                                                                                                                                                                                                                                                               |
| [14:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [11:8]  | TRGSEL5     | <b>BPWM_CH5 Trigger EADC Source Select</b><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                                                                                                                                                                                                                                                                                                                                                                               |
| [6:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3:0]   | TRGSEL4     | <b>BPWM_CH4 Trigger EADC Source Select</b><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.                                                                                                          |

|  |  |                                                                                                       |
|--|--|-------------------------------------------------------------------------------------------------------|
|  |  | 1000 = BPWM_CH5 up-count CMPDAT point.<br>1001 = BPWM_CH5 down-count CMPDAT point.<br>Others reserved |
|--|--|-------------------------------------------------------------------------------------------------------|

**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 |  |  |  | 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 |    |    |    |    |    | SSRC |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1    | 0  |
| Reserved |    |    |    |    |    |      |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                           |
| [9:8]   | SSRC        | <b>BPWM Synchronous Start Source Select</b><br>00 = Synchronous start source come from PWM0.<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]     | SSEN0       | <b>BPWM Synchronous Start Function 0 Enable Bit</b><br>When synchronous start function is enabled, the BPWM_CH0 counter enable bit (CNTEN0) 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 |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                       |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                             |
| [0]    | CNTSEN      | <p><b>BPWM Counter Synchronous Start Enable Bit(Write Only)</b></p> <p>BPWM counter synchronous enable function is used to make PWM or BPWM channels start counting at the same time.</p> <p>Writing this bit to 1 will also set the counter enable bit if correlated BPWM channel counter synchronous start function is enabled.</p> |

**BPWM Status Register (BPWM\_STATUS)**

| Register    | Offset         | R/W | Description          |  |  |  | Reset Value |
|-------------|----------------|-----|----------------------|--|--|--|-------------|
| BPWM_STATUS | BPWMx_BA+0x120 | R/W | BPWM Status Register |  |  |  | 0x0000_0000 |

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

| Bits               | Description |                                                                                                                                                                                                                                                                       |
|--------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                                             |
| [16+n]<br>n=0,1..5 | EADCTRGn    | <b>EADC Start of Conversion Status</b><br>Each bit n controls the corresponding BPWM channel n.<br>0 = No EADC start of conversion trigger event has occurred.<br>1 = An EADC start of conversion trigger event has occurred. Software can write 1 to clear this bit. |
| [15:1]             | Reserved    | Reserved.                                                                                                                                                                                                                                                             |
| [0]                | CNTMAX0     | <b>Time-base Counter 0 Equal to 0xFFFF Latched Status</b><br>0 = The time-base counter never reached its maximum value 0xFFFF.<br>1 = The time-base counter reached its maximum value. Software can write 1 to clear this bit.                                        |

**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]<br>n=0,1..5 | CAPINEN <sub>n</sub> | <p><b>Capture Input Enable Bits</b></p> <p>Each bit n controls the corresponding BPWM channel n.</p> <p>0 = BPWM Channel capture input path Disabled. The input of BPWM channel capture function is always regarded as 0.</p> <p>1 = BPWM Channel capture input path Enabled. The input of BPWM channel capture function comes from correlative multifunction pin.</p> |

**BPWM Capture Control Register (BPWM\_CAPCTL)**

| Register    | Offset         | R/W | Description                   |  |  |  | Reset Value |
|-------------|----------------|-----|-------------------------------|--|--|--|-------------|
| BPWM_CAPCTL | BPWMx_BA+0x204 | R/W | BPWM Capture Control Register |  |  |  | 0x0000_0000 |

|          |    |          |          |          |          |          |          |
|----------|----|----------|----------|----------|----------|----------|----------|
| 31       | 30 | 29       | 28       | 27       | 26       | 25       | 24       |
| Reserved |    | FCRLDEN5 | FCRLDEN4 | FCRLDEN3 | FCRLDEN2 | FCRLDEN1 | FCRLDEN0 |
| 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
| 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]            | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                  |
| [24+n]<br>n=0,1..5 | <b>FCRLDENn</b> | <b>Falling Capture Reload Enable Bits</b><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]            | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                  |
| [16+n]<br>n=0,1..5 | <b>RCRLDENn</b> | <b>Rising Capture Reload Enable Bits</b><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]            | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                  |
| [8+n]<br>n=0,1..5  | <b>CAPINVn</b>  | <b>Capture Inverter Enable Bits</b><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]              | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                  |
| [n]<br>n=0,1..5    | <b>CAPENn</b>   | <b>Capture Function Enable Bits</b><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 | 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 |    | CFIFOV5 | CFIFOV4 | CFIFOV3 | CFIFOV2 | CFIFOV1 | CFIFOV0 |
| 7        | 6  | 5       | 4       | 3       | 2       | 1       | 0       |
| Reserved |    | CRIFOV5 | CRIFOV4 | CRIFOV3 | CRIFOV2 | CRIFOV1 | CRIFOV0 |

| Bits              | Description |                                                                                                                                                                                                                                                                                                                         |
|-------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14]           | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                               |
| [8+n]<br>n=0,1..5 | CFIFOVn     | <p><b>Capture Falling Interrupt Flag Overrun Status (Read Only)</b></p> <p>This flag indicates if falling latch happened when the corresponding CAPFIF is 1. Each bit n controls the corresponding BPWM channel n.</p> <p><b>Note:</b> This bit will be cleared automatically when user clear corresponding CAPFIF.</p> |
| [7:6]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                               |
| [n]<br>n=0,1..5   | CRIFOVn     | <p><b>Capture Rising Interrupt Flag Overrun Status (Read Only)</b></p> <p>This flag indicates if rising latch happened when the corresponding CAPRIF is 1. Each bit n controls the corresponding BPWM channel n.</p> <p><b>Note:</b> This bit will be cleared automatically when user clear corresponding CAPRIF.</p>   |

**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 | 0x0000_0000 |
| BPWM_RCAPDAT1 | BPWMx_BA+0x214 | R   | BPWM Rising Capture Data Register 1 | 0x0000_0000 |
| BPWM_RCAPDAT2 | BPWMx_BA+0x21C | R   | BPWM Rising Capture Data Register 2 | 0x0000_0000 |
| BPWM_RCAPDAT3 | BPWMx_BA+0x224 | R   | BPWM Rising Capture Data Register 3 | 0x0000_0000 |
| BPWM_RCAPDAT4 | BPWMx_BA+0x22C | R   | BPWM Rising Capture Data Register 4 | 0x0000_0000 |
| BPWM_RCAPDAT5 | BPWMx_BA+0x234 | R   | BPWM Rising Capture Data Register 5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                               |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                     |
| [15:0]  | RCAPDAT     | <b>BPWM Rising Capture Data (Read Only)</b><br>When rising capture condition happened, the BPWM counter value will be saved in this register. |

**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 | 0x0000_0000 |
| BPWM_FCAPDAT1 | BPWMx_BA+0x218 | R   | BPWM Falling Capture Data Register 1 | 0x0000_0000 |
| BPWM_FCAPDAT2 | BPWMx_BA+0x220 | R   | BPWM Falling Capture Data Register 2 | 0x0000_0000 |
| BPWM_FCAPDAT3 | BPWMx_BA+0x228 | R   | BPWM Falling Capture Data Register 3 | 0x0000_0000 |
| BPWM_FCAPDAT4 | BPWMx_BA+0x230 | R   | BPWM Falling Capture Data Register 4 | 0x0000_0000 |
| BPWM_FCAPDAT5 | BPWMx_BA+0x238 | R   | BPWM Falling Capture Data Register 5 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                       |
| [15:0]  | FCAPDAT     | <b>BPWM Falling Capture Data (Read Only)</b><br>When falling capture condition happened, the BPWM counter value will be saved in this register. |

**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 | 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 |    | CAPFIEN5 | CAPFIEN4 | CAPFIEN3 | CAPFIEN2 | CAPFIEN1 | CAPFIENO |
| 7        | 6  | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved |    | CAPRIEN5 | CAPRIEN4 | CAPRIEN3 | CAPRIEN2 | CAPRIEN1 | CAPRIENO |

| Bits    | Description |                                                                                                                                                                                                                             |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                   |
| [13:8]  | CAPFIENn    | <b>BPWM Capture Falling Latch Interrupt Enable Bits</b><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    | <b>BPWM Capture Rising Latch Interrupt Enable Bits</b><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 |  |  |  |  | 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 |    | CAPFIF5 | CAPFIF4 | CAPFIF3 | CAPFIF2 | CAPFIF1 | CAPFIF0 |
| 7        | 6  | 5       | 4       | 3       | 2       | 1       | 0       |
| Reserved |    | CAPRIF5 | CAPRIF4 | CAPRIF3 | CAPRIF2 | CAPRIF1 | CAPRIF0 |

| Bits              | Description     |                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14]           | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                          |
| [8+n]<br>n=0,1..5 | <b>CAPFIFn</b>  | <p><b>BPWM Capture Falling Latch Interrupt Flag</b><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/> <b>Note:</b> This bit is cleared by writing 1 to it.</p> |
| [7:6]             | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                          |
| [n]<br>n=0,1..5   | <b>CAPRIFn</b>  | <p><b>BPWM Capture Rising Latch Interrupt Flag</b><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/> <b>Note:</b> This bit is cleared by writing 1 to it.</p>    |

**BPWM Period Register Buffer (BPWM\_PBUF)**

| Register  | Offset         | R/W | Description        |  |  |  | Reset Value |
|-----------|----------------|-----|--------------------|--|--|--|-------------|
| BPWM_PBUF | BPWMx_BA+0x304 | R   | BPWM PERIOD Buffer |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                          |
|---------|-------------|--------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                |
| [15:0]  | PBUF        | <b>BPWM Period Buffer (Read Only)</b><br>Used as PERIOD active register. |

**BPWM Comparator Register Buffer 0~5 (BPWM\_CMPBUF0~5)**

| Register     | Offset         | R/W | Description          | Reset Value |
|--------------|----------------|-----|----------------------|-------------|
| BPWM_CMPBUF0 | BPWMx_BA+0x31C | R   | BPWM CMPDAT 0 Buffer | 0x0000_0000 |
| BPWM_CMPBUF1 | BPWMx_BA+0x320 | R   | BPWM CMPDAT 1 Buffer | 0x0000_0000 |
| BPWM_CMPBUF2 | BPWMx_BA+0x324 | R   | BPWM CMPDAT 2 Buffer | 0x0000_0000 |
| BPWM_CMPBUF3 | BPWMx_BA+0x328 | R   | BPWM CMPDAT 3 Buffer | 0x0000_0000 |
| BPWM_CMPBUF4 | BPWMx_BA+0x32C | R   | BPWM CMPDAT 4 Buffer | 0x0000_0000 |
| BPWM_CMPBUF5 | BPWMx_BA+0x330 | R   | BPWM CMPDAT 5 Buffer | 0x0000_0000 |



| Bits    | Description |                                                                           |
|---------|-------------|---------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                 |
| [15:0]  | CMPBUF      | <b>BPWM Comparator Buffer (Read Only)</b><br>Used as CMP active register. |

## 6.13 Quadrature Encoder Interface (QEI)

### 6.13.1 Overview

There are two QEI controllers in this device. The Quadrature Encoder Interface (QEI) decodes speed of rotation and motion sensor information. It can be used in any application that uses a quadrature encoder for feedback.

### 6.13.2 Features

#### 6.13.2.1 Quadrature Encoder Interface (QEI) Features

- Up to two QEI controllers, QEI0 and QEI1.
- Two QEI phase inputs, QEA and QEB; One Index input.
- A 32-bit up/down Quadrature Encoder Pulse Counter (QEI\_CNT)
- A 32-bit software-latch Quadrature Encoder Pulse Counter Hold Register (QEI\_CNTHOLD)
- A 32-bit Quadrature Encoder Pulse Counter Index Latch Register (QEI\_CNTLATCH)
- A 32-bit Quadrature Encoder Pulse Counter Compare Register (QEI\_CNTCMP) with a Pre-set Maximum Count Register (QEI\_CNTMAX)
- One QEI control register (QEI\_CTL) and one QEI Status Register (QEI\_STATUS)
- Four Quadrature encoder pulse counter operation modes
  - Support x4 free-counting mode
  - Support x2 free-counting mode
  - Support x4 compare-counting mode
  - Support x2 compare-counting mode
- Encoder Pulse Width measurement mode
- Input frequency of QEA/QEB/IDX without noise filter must lower than PCLK/4
- Input frequency of QEA/QEB/IDX with noise filter must lower than Noise Filter Clk/8

### 6.13.3 Block Diagram



Figure 6.13-1 QEI Block Diagram

The QEI controller inputs, QEA and QEB, accept the outputs from a quadrature encoded source, such as incremental optical shaft encoder. Two channels, A and B, nominally 90 degrees out of phase, are required. A quadrature encoder usually provides an index signal (to pin INDEX) which can be used to indicate an absolute position. There is a noise filter and polarity control for each signal before QEI control unit.



Figure 6.13-2 QEI Clock Source Control

#### 6.13.4 Basic Configuration

##### 6.13.4.1 QEI0 Basic Configuration

- Clock Source Configuration
  - Enable QEI0 peripheral clock in QEI0CKEN (CLK\_APBCLK1[22]).
- Reset Configuration
  - Reset QEI0 controller in QEI0RST (SYS\_IPRST2[22]).
- Pin Configuration

| Group | Pin Name   | GPIO  | MFP   |
|-------|------------|-------|-------|
| QEI0  | QEI0_A     | PD.11 | MFP10 |
|       |            | PE.3  | MFP11 |
|       |            | PA.4  | MFP14 |
|       | QEI0_B     | PD.10 | MFP10 |
|       |            | PE.2  | MFP11 |
|       |            | PA.3  | MFP14 |
|       | QEI0_INDEX | PD.12 | MFP10 |
|       |            | PE.4  | MFP11 |
|       |            | PA.5  | MFP14 |

##### 6.13.4.2 QEI1 Basic Configuration

- Clock Source Configuration
  - Enable QEI1 peripheral clock in QEI1CKEN (CLK\_APBCLK1[23]).
- Reset Configuration
  - Reset QEI1 controller in QEI1RST (SYS\_IPRST2[23]).
- Pin Configuration

| Group | Pin Name | GPIO | MFP   |
|-------|----------|------|-------|
| QEI1  | QEI1_A   | PA.9 | MFP10 |

|            |  |       |       |
|------------|--|-------|-------|
|            |  | PE.6  | MFP11 |
|            |  | PA.13 | MFP12 |
| QEI1_B     |  | PA.8  | MFP10 |
|            |  | PE.5  | MFP11 |
|            |  | PA.14 | MFP12 |
| QEI1_INDEX |  | PA.10 | MFP10 |
|            |  | PE.7  | MFP11 |
|            |  | PA.12 | MFP12 |

### 6.13.5 Functional Description

The QEI control logic detects the relation of phase lead/lag between the filtered signals CHA and CHB and CHX to produce direction indication bit DDIR(QEI\_STATUS[8]) to control the pulse counter. The comparator/reload logic compares the pulse counter and maximum count and control the function of reloading pulse counter in compare-counting mode. In Free-counting mode the pulse counter CNT(QEI\_CNT[31:0]) will count until the 0xFFFF\_FFFF value; while in Compare-counting mode the pulse counter will counts until the CNTMAX (QEI\_CNTMAX[31:0]) and the pulse counter will be reset to 0 to restart the next cyclic counting.

#### 6.13.5.1 Input Noise Filter

Each pin of QEI inputs is equipped with a noise filter which can filter the unwanted noise from. The QEA, QEB and IDX noise filters can be disabled through bits NFDIS (QEI\_CTL[3]). If enabled, the capture logic is required to sample 4 consecutive same capture input value in order to recognize an edge as a capture event. In Figure 6.13-5, it is a possible implementation of digital noise filter; the interval between pulses requirement for input capture is 4 QEI\_CLK clocks width. Any pulse width less than or equal to 3 QEI\_CLK clocks will not have any trigger. The timing requirement through Noise Filter is also shown in Figure 6.13-5. CHA, CHB and CHX are the outputs of QEA, QEB and IDX respectively after going through noise filter and polarity control. Refer to Figure 6.13-3. If the noise filter is disabled the input signals QEA, QEB and IDX are passed to the internal signals CHA, CHB and CHX respectively without any delay.



Figure 6.13-3 Noise Filter



Figure 6.13-4 Noise Filter Sampling Clock Selection



Figure 6.13-5 QEA/QEB/IDX Timing Requirement through Noise Filter

### 6.13.5.2 Operation of Quadrature Encoder Interface

There are four Quadrature encoder pulse counter operation modes:

- Mode0: x4 free-counting mode
- Mode1: x2 free-counting mode
- Mode2: x4 compare-counting mode
- Mode3: x2 compare-counting mode

#### 6.13.5.3 Free-counting mode

The quadrature encoder pulse counter CNT(QEI\_CNT[31:0]) up or down counts according to the direction indication bit DIRF (QEI\_STATUS[8]). When overflow or underflow occurs, it sets flag OVUNF (QEI\_STATUS[2]). Refer to Figure 6.13-6 and Figure 6.13-7 for detailed timing.

#### 6.13.5.4 Compare-counting Mode

The pulse counter up or down counts according to the direction indication bit DIRF (QEI\_STATUS[8]).

On up counting, flag OVUNF (QEI\_STATUS[2]) will be asserted when CNT(QEI\_CNT[31:0]) overflows from CNTMAX (QEI\_CNTMAX[31:0]) to 0 on the next CHA edge for x2 counting mode, and on CHA/CHB edge for x4 counting mode. On down counting, flag OVUNF (QEI\_STATUS[2]) will be asserted when CNT(QEI\_CNT[31:0]) underflows from 0 to CNTMAX (QEI\_CNTMAX[31:0]) on the next CHA edge for x2 counting mode, and on CHA/CHB edge for x4 counting mode. This mode provides the position of a rotor to user. If a quadrature encoder output 1024 pulses to CHA per round, user can write QEI\_MAXCNT and CNTCMP(QEI\_CNTCMP[31:0]) with 4095 in x4 mode or 2047 in x2 mode and reset CNT(QEI\_CNT[31:0]) at initial before compare-counting mode is active. When the CNT(QEI\_CNT[31:0]) overflows from CNTCMP(QEI\_CNTCMP[31:0]), here CNTCMP(QEI\_CNTCMP[31:0]) should be preset the same value as CNTMAX (QEI\_CNTMAX[31:0]), it means rotor runs one round on next CHA/CHB edge. Refer to Figure 6.13-6 and Figure 6.13-7 for detailed timing.

#### 6.13.5.5 X4/X2 Counting Modes

In **X4 Counting mode**, the pulse counter increases or decreases one on every CHA and CHB edge based on the phase relationship of CHA and CHB signals.

QEI x4 Counting mode provides a finer resolution of the rotor position, since the counter increments or decrements more frequently for each QEA/QEB input pulse pair than in QEI x2 mode. This mode is selected by setting the QEI Counting Mode Selection bits MODE(QEI\_CTL[9:8]) to 00b or 01b. In this mode, the QEI logic detects every edge on every QEA and QEB input edges.



Figure 6.13-6 X4 Counting Mode

In **X2 Counting mode**, the pulse counter increases or decreases one on every CHA edge based on the phase relationship of CHA and CHB signals.

QEI x2 Counting mode is selected by setting the QEI Counting Mode Selection bits (QEI\_CTL[9:8]) to 01b or 11b. In this mode, the QEI logic detects every edge on the QEA input only. Every rising and falling edge on the QEA signal clocks the pulse counter.



Figure 6.13-7 X2 Counting Mode

#### 6.13.5.6 Direction of Counting

If CHA leads CHB, the pulse counter is increased by 1. If CHA lags CHB, the pulse counter is decreased by 1. The QEI control logic generates a signal that sets the DIRF (QEI\_STATUS[8]); this in turn determines the direction of the count. When CHA leads CHB, DIRF(QEI\_STATUS[8]) is set as 1, and the position counter increments on every active edge. When CHA lags CHB, DIRF(QEI\_STATUS[8]) is cleared, and the position counter decrements on every active edge. Refer to Table 6.13-1.

| Current Signal Detected | Previous Signal Detected |     |         |     | DIR (Counting Direction)  |  |
|-------------------------|--------------------------|-----|---------|-----|---------------------------|--|
|                         | Rising                   |     | Falling |     |                           |  |
|                         | CHA                      | CHB | CHA     | CHB |                           |  |
| CHA rising              |                          |     |         | ✓   | 1 (Increment)             |  |
|                         |                          | ✓   |         |     | 0 (Decrement)             |  |
|                         |                          |     | ✓       |     | Toggle (direction change) |  |
| CHA falling             |                          |     |         | ✓   | 0 (Decrement)             |  |
|                         |                          | ✓   |         |     | 1 (Increment)             |  |
|                         | ✓                        |     |         |     | Toggle (direction change) |  |
| CHB rising              | ✓                        |     |         |     | 1 (Increment)             |  |
|                         |                          |     | ✓       |     | 0 (Decrement)             |  |
|                         |                          |     |         | ✓   | Toggle (direction change) |  |

|             |   |   |   |  |                           |
|-------------|---|---|---|--|---------------------------|
| CHB falling |   |   | ✓ |  | 1 (Increment)             |
|             | ✓ |   |   |  | 0 (Decrement)             |
|             |   | ✓ |   |  | Toggle (direction change) |

Table 6.13-1 Direction of Counting

#### 6.13.5.7 Up-Counting

Under the forward direction the DIRF(QEI\_STATUS[8]) bit is 1 when up-counting. Software needs to clear the OVUNF (QEI\_STATUS[2]) flag. For the free-counting mode the CNT(QEI\_CNT[31:0]) counter will count until it matches 0xFFFF\_FFFF and next edges on the forward direction will set the bit OVUNF (QEI\_STATUS[2]) high and reset CNT(QEI\_CNT[31:0]) to 0. For compare-counting mode the CNT(QEI\_CNT[31:0]) counter counts until the CNTMAX (QEI\_CNTMAX[31:0]) value and next edges on the forward direction will set the bit OVUNF (QEI\_STATUS[2]) high and reset CNT(QEI\_CNT[31:0]) to 0. Changes of direction trigger a down-count and CNT(QEI\_CNT[31:0]) decreasing in counter value. For X2 mode, only CHA edge will set OVUNF (QEI\_STATUS[2]) while for X4 mode both CHA and CHB edges will set OVUNF (QEI\_STATUS[2]).

#### 6.13.5.8 Down-Counting

A change of direction will cause the counter to down count for X2/X4 counting mode. It is indicated with the DIRF(QEI\_STATUS[8]) bit as 0 and DIRCHGF (QEI\_STATUS[3]) flag is set to 1. At this stage the CNT(QEI\_CNT[31:0]) will start to down-count. In free-counting mode the pulse counter will reload with 0xFFFF\_FFFF when it down counts to 0 and sets OVUNF (QEI\_STATUS[2]) to high in the next edge. The pulse counter will reload with CNTMAX (QEI\_CNTMAX[31:0]) when it down counts to 0 in compare-counting mode and sets OVUNF (QEI\_STATUS[2]) to high in the next edge. For X2 mode, only CHA edge will set OVUNF (QEI\_STATUS[2]) while for X4 mode both CHA and CHB edges will set OVUNF (QEI\_STATUS[2]).

#### 6.13.5.9 Compare Function

The compare function in QEI controller is to compare the dynamic counting CNT(QEI\_CNT[31:0]) with the compare register CNTCMP(QEI\_CNTCMP[31:0]). When CNT(QEI\_CNT[31:0]) up or down counts and reaches CNTCMP(QEI\_CNTCMP[31:0]), the flag CMPF(QEI\_STATUS[1]) will be set. Set bit CMP\_EN (QEI\_CTL[28]) to one to enable the compare function otherwise disable it.



Figure 6.13-8 Compare Operation

#### 6.13.5.10 Reload Counter by Pin IDX

The CNT(QEI\_CNT[31:0]) counter can be reset to 0 or reload with the content of CNTMAX (QEI\_CNTMAX[31:0]) by the signal CHX (the filtered and polarity-set output of pin IDX) trigger. When the IDX Reload bit IDXRLD\_EN(QEI\_CTL[27]) is set, a rising edge of CHX causes QEI controller to reset the CNT(QEI\_CNT[31:0]) to 0 if the counter is in up-counting; if the counter is in down-counting the rising edge of CHX causes the QEI controller to reload the CNT(QEI\_CNT[31:0]) with the content

of CNTMAX (QEI\_CNTMAX[31:0]). Refer to Figure 6.13-9 for details.



Figure 6.13-9 QEI\_CNT Reload/Reset Control

#### 6.13.5.11 Capture QEI Counter

If the bit HOLDCNT(QEI\_CTL[24]) is set, the CNT(QEI\_CNT[31:0]) content will be captured into QEI Counter Hold Register CNTHOLD(QEI\_CNTHOLD[31:0]), the data will be held until the next HOLDCNT (QEI\_CTL[24]) trigger comes. The bit HOLDCNT can be set by writing 1 to it or the rising edge of timers interrupt flags TIF (TIMERx\_INTSTS[0]).

**Note:** The bit HOLDCNT is automatically cleared by hardware after CNTHOLD(QEI\_CNTHOLD[31:0]) captures the content of QEI counter.

If the bit IDXLATEN (QEI\_CTL[25]) is set, the CNT(QEI\_CNT[31:0]) content will be latched into QEI Counter Index Latch Register CNTLATCH (QEI\_CNTLATCH[31:0]) at every rising edge of CHX signal.



Figure 6.13-10 Trigger Control of Capturing QEI Counter



Figure 6.13-11 Capture and Latch QEI Counter

#### 6.13.5.12 QEI Interrupt Architecture

There are four interrupt sources, each one of them has an interrupt flag and enable control bit, to trigger QEI Interrupt. When the QEI counter is up-counting and CNT(QEI\_CNT[31:0]) overflows or down-counting and underflows, the Overflow/Underflow flag OVUNF (QEI\_STATUS[2]) will be set by hardware and it will trigger QEI Interrupt request if bit OVUNIEN (QEI\_CTL[16]) is high. When QEI controller detects the encoder rotation change, it toggles the direction indication bit DDIRF (QEI\_STATUS[8]) and the direction change flag DIRCHGF (QEI\_STATUS[3]) will be set by hardware that requests the QEI interrupt if bit DIRIEN (QEI\_CTL[17]) is set. When the QEI counter counting value is equal to the value of QEI Counter Compare Register (CNTCMP(QEI\_CNTCMP[31:0])), the flag CMPF (QEI\_STATUS[1]) will be set by hardware and the QEI Interrupt will be requested if bit CMPIEN (QEI\_CTL[18]) is high. When QEI controller detects a rising edge at signal CHX (the filtered and polarity-set output of pin IDX), the flag IDXF(QEI\_STATUS[1]) will set by hardware and the QEI interrupt will be requested if bit IDXIEN (QEI\_CTL[19]) is set. Note that the four flags, OVUNF(QEI\_STATUS[2]), DIRCHGF(QEI\_STATUS[3]), CMPF(QEI\_STATUS[1]) and IDXF(QEI\_STATUS[0]) are set by hardware and must be cleared by software. Figure 6.13-12 demonstrates the architecture of Quadrature Encoder Interface Controller interrupts.



Figure 6.13-12 Quadrature Encoder Interface Interrupt Architecture Diagram

### 6.13.6 Register Map

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

| Register                 | Offset       | R/W | Description                        | Reset Value |
|--------------------------|--------------|-----|------------------------------------|-------------|
| <b>QEI Base Address:</b> |              |     |                                    |             |
| QEIO_BA = 0x400B_0000    |              |     |                                    |             |
| QEII_BA = 0x400B_1000    |              |     |                                    |             |
| QEI_CNT<br>x=0, 1        | QEIx_BA+0x00 | R/W | QEI Counter Register               | 0x0000_0000 |
| QEI_CNTHOLD<br>x=0, 1    | QEIx_BA+0x04 | R/W | QEI Counter Hold Register          | 0x0000_0000 |
| QEI_CNTLATCH<br>x=0,1    | QEIx_BA+0x08 | R/W | QEI Counter Index Latch Register   | 0x0000_0000 |
| QEI_CNTCMP<br>x=0, 1     | QEIx_BA+0x0C | R/W | QEI Counter Compare Register       | 0x0000_0000 |
| QEI_CNTMAX<br>x=0, 1     | QEIx_BA+0x14 | R/W | QEI Pre-set Maximum Count Register | 0x0000_0000 |
| QEI_CTL<br>x=0, 1        | QEIx_BA+0x18 | R/W | QEI Controller Control Register    | 0x0000_0000 |
| QEI_STATUS<br>x=0, 1     | QEIx_BA+0x2C | R/W | QEI Controller Status Register     | 0x0000_0000 |

### 6.13.7 Register Description

#### QEI Counter Register (QEI\_CNT)

| Register | Offset       | R/W | Description          |  |  |  | Reset Value |
|----------|--------------|-----|----------------------|--|--|--|-------------|
| QEI_CNT  | QEIx_BA+0x00 | R/W | QEI Counter Register |  |  |  | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CNT         | <b>Quadrature Encoder Interface Counter</b><br>A 32-bit up/down counter. When an effective phase pulse is detected, this counter is increased by one if the bit DIRF (QEI_STATUS[8]) is one or decreased by one if the bit DIRF(QEI_STATUS[8]) is 0. This register performs an integrator which count value is proportional to the encoder position. The pulse counter may be initialized to a predetermined value by one of three events occurs:<br>1. Software is written if QEIEN (QEI_CTL[29]) = 0.<br>2. Compare-match event if QEIEN(QEI_CTL[29])=1 and QEI is in compare-counting mode.<br>3. Index signal change if QEIEN(QEI_CTL[29])=1 and IDXRLDEN (QEI_CTL[27])=1. |

**QEI Counter Hold Register (QEI\_CNTHOLD)**

| Register    | Offset       | R/W | Description               | Reset Value |
|-------------|--------------|-----|---------------------------|-------------|
| QEI_CNTHOLD | QEIx_BA+0x04 | R/W | QEI Counter Hold Register | 0x0000_0000 |

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

| Bits   | Description    |                                                                                                                                                                                           |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>CNTHOLD</b> | <b>Quadrature Encoder Interface Counter Hold</b><br>When the bit HOLDCNT (QEI_CTL[24]) goes from low to high, the CNT(QEI_CNT[31:0]) is copied into CNTHOLD (QEI_CNTHOLD[31:0]) register. |

**QEI Counter Index Latch Register (QEI\_CNTLATCH)**

| Register     | Offset       | R/W | Description                      | Reset Value |
|--------------|--------------|-----|----------------------------------|-------------|
| QEI_CNTLATCH | QEIx_BA+0x08 | R/W | QEI Counter Index Latch Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                    |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CNTLATCH    | <b>Quadrature Encoder Interface Counter Index Latch</b><br>When the IDXF (QEI_STATUS[0]) bit is set, the CNT(QEI_CNT[31:0]) is copied into CNTLATCH (QEI_CNTLATCH[31:0]) register. |

**QEI Counter Compare Register (QEI\_CNTCMP)**

| Register   | Offset       | R/W | Description                  |  |  |  | Reset Value |
|------------|--------------|-----|------------------------------|--|--|--|-------------|
| QEI_CNTCMP | QEIx_BA+0x0C | R/W | QEI Counter Compare Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description   |                                                                                                                                                                                                                                                                   |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>CNTCMP</b> | <b>Quadrature Encoder Interface Counter Compare</b><br>If the QEI controller is in the compare-counting mode CMPEN (QEI_CTL[28]) =1, when the value of CNT(QEI_CNT[31:0]) matches CNTCMP(QEI_CNTCMP[31:0]), CMPF will be set. This register is software writable. |

**QEI Pre-set Maximum Count Register (QEI\_CNTMAX)**

| Register   | Offset       | R/W | Description                        |  |  |  | Reset Value |
|------------|--------------|-----|------------------------------------|--|--|--|-------------|
| QEI_CNTMAX | QEIx_BA+0x14 | R/W | QEI Pre-set Maximum Count Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description   |                                                                                                                                                                                                                      |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>CNTMAX</b> | <b>Quadrature Encoder Interface Preset Maximum Count</b><br>This register value determined by user stores the maximum value which may be the number of the QEI counter for the QEI controller compare-counting mode. |

**QEI Controller Control Register (QEI\_CTL)**

| Register | Offset       | R/W | Description                     |  |  |  | Reset Value |
|----------|--------------|-----|---------------------------------|--|--|--|-------------|
| QEI_CTL  | QEIx_BA+0x18 | R/W | QEI Controller Control Register |  |  |  | 0x0000_0000 |

| 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
|----------|----------|----------|----------|----------|----------|----------|----------|
|          |          | Reserved | QEIEN    | CMPEN    | IDXRLDEN | Reserved | IDXLATEN |
| 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| HOLDTMR3 | HOLDTMR2 | HOLDTMR1 | HOLDTMR0 | IDXIEN   | CMPIEN   | DIRIEN   | OVUNIEN  |
| 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved | IDXINV   | CHBINV   | CHAINV   | Reserved |          | MODE     |          |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved | IDXEN    | CHBEN    | CHAEN    | NFDIS    | NFCLKSEL |          |          |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [29]    | QEIEN       | <b>Quadrature Encoder Interface Controller Enable Bit</b><br>0 = QEI controller function Disabled.<br>1 = QEI controller function Enabled.                                                                                                                                                                                                                                                                                                                                |
| [28]    | CMPEN       | <b>The Compare Function Enable Bit</b><br>The compare function in QEI controller is to compare the dynamic counting QEI_CNT with the compare register CNTCMP( QEI_CNTCMP[31:0] ), if CNT(QEI_CNT[31:0]) reaches CNTCMP( QEI_CNTCMP[31:0] ), the flag CMPF will be set.<br>0 = Compare function Disabled.<br>1 = Compare function Enabled.                                                                                                                                 |
| [27]    | IDXRLDEN    | <b>Index Trigger QEI_CNT Reload Enable Bit</b><br>When this bit is high and a rising edge comes on signal CHX, the CNT(QEI_CNT[31:0]) will be reset to 0 if the counter is in up-counting type (DIRF(QEI_STATUS[8]) = 1); while the CNT(QEI_CNT[31:0]) will be reloaded with CNTMAX (QEI_CNTMAX[31:0]) content if the counter is in down-counting type (DIRF(QEI_STATUS[8]) = 0).<br>0 = Reload function Disabled.<br>1 = QEI_CNT re-initialized by Index signal Enabled. |
| [26]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [25]    | IDXLATEN    | <b>Index Latch QEI_CNT Enable Bit</b><br>If this bit is set to high, the CNT(QEI_CNT[31:0]) content will be latched into CNTLATCH (QEI_CNTLATCH[31:0]) at every rising on signal CHX.<br>0 = The index signal latch QEI counter function Disabled.<br>1 = The index signal latch QEI counter function Enabled.                                                                                                                                                            |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [24]    | <b>HOLDCNT</b>  | <b>Hold QEI_CNT Control</b><br>When this bit is set from low to high, the CNT(QEI_CNT[31:0]) is copied into CNTHOLD(QEI_CNT[31:0]). This bit may be set by writing 1 to it or Timer0~Timer3 interrupt flag TIF (TIMERx_INTSTS[0]).<br>0 = No operation.<br>1 = QEI_CNT content is captured and stored in CNTHOLD(QEI_CNT[31:0]).<br><b>Note:</b> This bit is automatically cleared after QEI_CNT holds QEI_CNT value. |
| [23]    | <b>HOLDTMR3</b> | <b>Hold QEI_CNT by Timer 3</b><br>0 = TIF (TIMER3_INTSTS[0]) has no effect on HOLDCNT.<br>1 = A rising edge of bit TIF(TIMER3_INTSTS[0]) in timer 3 sets HOLDCNT to 1.                                                                                                                                                                                                                                                |
| [22]    | <b>HOLDTMR2</b> | <b>Hold QEI_CNT by Timer 2</b><br>0 = TIF(TIMER2_INTSTS[0]) has no effect on HOLDCNT.<br>1 = A rising edge of bit TIF(TIMER2_INTSTS[0]) in timer 2 sets HOLDCNT to 1.                                                                                                                                                                                                                                                 |
| [21]    | <b>HOLDTMR1</b> | <b>Hold QEI_CNT by Timer 1</b><br>0 = TIF(TIMER1_INTSTS[0]) has no effect on HOLDCNT.<br>1 = A rising edge of bit TIF (TIMER1_INTSTS[0]) in timer 1 sets HOLDCNT to 1.                                                                                                                                                                                                                                                |
| [20]    | <b>HOLDTMR0</b> | <b>Hold QEI_CNT by Timer 0</b><br>0 = TIF (TIMER0_INTSTS[0]) has no effect on HOLDCNT.<br>1 = A rising edge of bit TIF(TIMER0_INTSTS[0]) in timer 0 sets HOLDCNT to 1.                                                                                                                                                                                                                                                |
| [19]    | <b>IDXIEN</b>   | <b>IDXF Trigger QEI Interrupt Enable Bit</b><br>0 = The IDXF can trigger QEI interrupt Disabled.<br>1 = The IDXF can trigger QEI interrupt Enabled.                                                                                                                                                                                                                                                                   |
| [18]    | <b>CMPien</b>   | <b>CMPF Trigger QEI Interrupt Enable Bit</b><br>0 = CMPF can trigger QEI controller interrupt Disabled.<br>1 = CMPF can trigger QEI controller interrupt Enabled.                                                                                                                                                                                                                                                     |
| [17]    | <b>DIRIEN</b>   | <b>DIRCHGF Trigger QEI Interrupt Enable Bit</b><br>0 = DIRCHGF can trigger QEI controller interrupt Disabled.<br>1 = DIRCHGF can trigger QEI controller interrupt Enabled.                                                                                                                                                                                                                                            |
| [16]    | <b>OVUNIEN</b>  | <b>OVUNF Trigger QEI Interrupt Enable Bit</b><br>0 = OVUNF can trigger QEI controller interrupt Disabled.<br>1 = OVUNF can trigger QEI controller interrupt Enabled.                                                                                                                                                                                                                                                  |
| [15]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                             |
| [14]    | <b>IDXINV</b>   | <b>Inverse IDX Input Polarity</b><br>0 = Not inverse IDX input polarity.<br>1 = IDX input polarity is inverted to QEI controller.                                                                                                                                                                                                                                                                                     |
| [13]    | <b>CHBINV</b>   | <b>Inverse QEB Input Polarity</b><br>0 = Not inverse QEB input polarity.<br>1 = QEB input polarity is inverted to QEI controller.                                                                                                                                                                                                                                                                                     |
| [12]    | <b>CHAINV</b>   | <b>Inverse QEA Input Polarity</b><br>0 = Not inverse QEA input polarity.<br>1 = QEA input polarity is inverted to QEI controller.                                                                                                                                                                                                                                                                                     |
| [11:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                             |

|       |                 |                                                                                                                                                                                                                                            |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9:8] | <b>MODE</b>     | <b>QEI Counting Mode Selection</b><br>There are four quadrature encoder pulse counter operation modes.<br>00 = X4 Free-counting Mode.<br>01 = X2 Free-counting Mode.<br>10 = X4 Compare-counting Mode.<br>11 = X2 Compare-counting Mode.   |
| [7]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                  |
| [6]   | <b>IDXEN</b>    | <b>IDX Input to QEI Controller Enable Bit</b><br>0 = IDX input to QEI Controller Disabled.<br>1 = IDX input to QEI Controller Enabled.                                                                                                     |
| [5]   | <b>CHBEN</b>    | <b>QEB Input to QEI Controller Enable Bit</b><br>0 = QEB input to QEI Controller Disabled.<br>1 = QEB input to QEI Controller Enabled.                                                                                                     |
| [4]   | <b>CHAEN</b>    | <b>QEA Input to QEI Controller Enable Bit</b><br>0 = QEA input to QEI Controller Disabled.<br>1 = QEA input to QEI Controller Enabled.                                                                                                     |
| [3]   | <b>NFDIS</b>    | <b>QEI Controller Input Noise Filter Disable Bit</b><br>0 = The noise filter of QEI controller Enabled.<br>1 = The noise filter of QEI controller Disabled.                                                                                |
| [2:0] | <b>NFCLKSEL</b> | <b>Noise Filter Clock Pre-divide Selection</b><br>To determine the sampling frequency of the Noise Filter clock .<br>000 = QEI_CLK.<br>001 = QEI_CLK/2.<br>010 = QEI_CLK/4.<br>011 = QEI_CLK/16.<br>100 = QEI_CLK/32.<br>101 = QEI_CLK/64. |

QEI Controller Status Register (QEI\_STATUS)

| Register   | Offset       | R/W | Description                    |  |  |  |  | Reset Value |
|------------|--------------|-----|--------------------------------|--|--|--|--|-------------|
| QEI_STATUS | QEIx_BA+0x2C | R/W | QEI Controller 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 |    |    |    | DIRCHGF | OVUNF | CMPF | IDXF |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [8]    | DIRF        | <b>QEI Counter Counting Direction Indication</b><br>0 = QEI Counter is in down-counting.<br>1 = QEI Counter is in up-counting.<br><b>Note:</b> This bit is set/reset by hardware according to the phase detection between CHA and CHB.                                                                                                                                                                                                                                                                                 |
| [7:4]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [3]    | DIRCHGF     | <b>Direction Change Flag</b><br>Flag is set by hardware while QEI counter counting direction is changed. Software can clear this bit by writing 1 to it.<br>0 = No change in QEI counter counting direction.<br>1 = QEI counter counting direction is changed.<br><b>Note:</b> This bit is only cleared by writing 1 to it.                                                                                                                                                                                            |
| [2]    | OVUNF       | <b>QEI Counter Overflow or Underflow Flag</b><br>Flag is set by hardware while CNT(QEI_CNT[31:0]) overflows from 0xFFFF_FFFF to 0 in free-counting mode or from the CNTMAX (QEI_CNTMAX[31:0]) to 0 in compare-counting mode. Similarly, the flag is set while QEI counter underflows from 0 to 0xFFFF_FFFF or CNTMAX (QEI_CNTMAX[31:0]).<br>0 = No overflow or underflow occurs in QEI counter.<br>1 = QEI counter occurs counting overflow or underflow.<br><b>Note:</b> This bit is only cleared by writing 1 to it. |
| [1]    | CMPF        | <b>Compare-match Flag</b><br>If the QEI compare function is enabled, the flag is set by hardware while QEI counter up or down counts and reach to the CNTCMP(QEI_CNTCMP[31:0]).<br>0 = QEI counter does not match with CNTCMP(QEI_CNTCMP[31:0]).<br>1 = QEI counter counts to the same as CNTCMP(QEI_CNTCMP[31:0]).<br><b>Note:</b> This bit is only cleared by writing 1 to it.                                                                                                                                       |

|     |             |                                                                                                                                                                                                                                                                              |
|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | <b>IDXF</b> | <b>IDX Detected Flag</b><br>When the QEI controller detects a rising edge on signal CHX it will set flag IDXF to high.<br>0 = No rising edge detected on signal CHX.<br>1 = A rising edge occurs on signal CHX.<br><b>Note:</b> This bit is only cleared by writing 1 to it. |
|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## 6.14 Enhanced Input Capture Timer (ECAP)

### 6.14.1 Overview

This device provides up to two units of Input Capture Timer/Counter whose capture function can detect the digital edge-changed signal at channel inputs. Each unit has three input capture channels. The timer/counter is equipped with up counting, reload and compare-match capabilities.

### 6.14.2 Features

- Up to two Input Capture Timer/Counter units, CAP0 and CAP1.
- Each unit has 3 input channels.
- Each unit has its own interrupt vector.
- Each input channel has its own capture counter hold register.
- 24-bit Input Capture up-counting timer/counter.
- With noise filter in front end of input ports.
- Edge detector with three options:
  - Rising edge detection
  - Falling edge detection
  - Both edge detection
- Captured events reset and/or reload capture counter.
- Supports compare-match function.

### 6.14.3 Block Diagram



Figure 6.14-1 Input Capture Timer/Counter Architecture

#### 6.14.4 Basic Configuration

##### 6.14.4.1 ECAP0 Basic Configuration

- Clock Source Configuration
  - Enable ECAP0 peripheral clock in ECAP0CKEN(CLK\_APBCLK1[26]).
- Reset Configuration
  - Reset ECAP0 peripheral in ECAP0RST (SYS\_IPRST2[26]).
- Pin Configuration

| Group | Pin Name  | GPIO  | MFP   |
|-------|-----------|-------|-------|
| ECAP0 | ECAP0_IC0 | PA.10 | MFP11 |
|       |           | PE.8  | MFP12 |
|       | ECAP0_IC1 | PA.9  | MFP11 |
|       |           | PE.9  | MFP12 |
|       | ECAP0_IC2 | PA.8  | MFP11 |
|       |           | PE.10 | MFP12 |

##### 6.14.4.2 ECAP1 Basic Configuration

- Clock Source Configuration
  - Enable ECAP1 peripheral clock in ECAP1CKEN (CLK\_APBCLK1[27]).
- Reset Configuration
  - Reset ECAP1 peripheral in ECAP1RST (SYS\_IPRST2[27]).
- Pin Configuration

| Group | Pin Name  | GPIO  | MFP   |
|-------|-----------|-------|-------|
| ECAP1 | ECAP1_IC0 | PC.10 | MFP11 |
|       |           | PE.13 | MFP13 |
|       | ECAP1_IC1 | PC.11 | MFP11 |
|       |           | PE.12 | MFP13 |
|       | ECAP1_IC2 | PC.12 | MFP11 |
|       |           | PE.11 | MFP13 |

### 6.14.5 Functional Description



Figure 6.14-2 Input Capture Timer/Counter Clock Source Control

Figure 6.14-1 illustrates the architecture of the Input Capture. Each input capture timer/counter unit supports 3 input channels with programmable input signal sources. The port pins ECAP\_IC0 to ECAP\_IC2 can be fed to the inputs of capture unit through noise filter or bypass it (CAPNFDIS = 1), and the QEI controller input signals (CHA, CHB and CHX) also can be internally routed to the capture inputs by setting the register ECAP\_CTL0(CAPSEL0~ CAPSEL 2).

#### 6.14.5.1 Input Noise Filter

The architecture of input noise filter is similar to that one used for QEI (refer to Figure 6.13-3). With 6 sampling-rate options, it supports a wide range of filtering noise whose duration is from 33 ns (NFCLKSEL = 000) to 2.1 us (NFCLKSEL = 101) while PCLK is running at the frequency of 90 MHz. Table 6.14-1 lists the relation between the setting of NFCLKSEL, the duration of filtered noise and the duration of the signal that is guaranteed to be sampled.

The maximum duration of the noise that is filtered out should not be more than 3 clock cycle, while the minimum duration of the signal that is guaranteed to be sampled should be more than 4 clock cycle.

| NFCLKSEL     | Maximum Duration Of Noise | Minimum Duration Of Signal |
|--------------|---------------------------|----------------------------|
| 000          | 33 ns                     | 44 ns                      |
| 001          | 67 ns                     | 89 ns                      |
| 010          | 133 ns                    | 178 ns                     |
| 011          | 533 ns                    | 711 ns                     |
| 100          | 1067 ns                   | 1422 ns                    |
| 101          | 2133 ns                   | 2844 ns                    |
| PCLK= 90 MHz |                           |                            |

Table 6.14-1 Typical Case of Noise Filter Settings



Figure 6.14-3 Noise Filter Sampling Clock Selection



Figure 6.14-4 Input Capture Timer/Counter Function Block

#### 6.14.5.2 Input Capture Timer/Counter Operation

An Input Capture Timer/Counter unit consists of 2 main functional blocks, Capture block and Operation block. There are 3 Input Capture units in Capture block for 3 input channel.

The capture units function as detecting and measuring the pulse width and the period of a square wave. The input channel 0 to 2 have their own edge detectors, which are in Input Capture block but share with one capture timer/counter, ECAP\_CNT, which is in Operation block. The edge trigger option is programmable through EDGESEL (ECAP\_CTL1[5,4], [3,2], [1,0]) register supporting positive edge, negative edge and both edge triggers. Each capture unit consists of an enable control bit, IC0EN ~ IC2EN (ECAP\_CTL0[6:4]) to enable/disable each input channel and a status bit CAP0 ~ CAP2 (ECAP\_STATUS[10:8]) to let software monitor the current status of each channel.

The Input Capture supports reload mode and compare mode. For both mode, the capture counter (ECAP\_CNT) serves as a 24-bit up-counting counter whose clock comes from the output of the clock divider and is gated with CNTEN, and the clock source of the clock divider, which can be set by CLKSEL[2:0] to divide clock by 1,4,16,32,64,96,112 and 128, is programmable (by setting CNTSRCSEL[1:0]) to be from system clock source, CAP\_CLK or input channel CAP0 ~ CAP2. In reload mode, ECAP\_CNTCMP serves as a reload register while in compare mode ECAP\_CNTCMP serves as a compare register. The Input Capture Timer/Counter Enable bit (CAPEN) must be set to enable Input Capture Timer/Counter functions. More details of operation are described in the following.

### Capture Function

Each time when the capture input detect a valid edge change, it triggers a valid capture event (CAPTE0~2) so that the content of the free running 24-bit capture counter ECAP\_CNT will be captured/transferred into the capture hold registers, ECAP\_HLD0~2 depending on which channel is triggered. This event also causes the corresponding flag CAPTFx (ECAP\_STATUS[2:0]) to be set, which will generate an interrupt if the corresponding interrupt enable bit CAPIENx (ECAP\_CTL0[18:16]) is set. Triggered Flags are set by hardware and should be cleared by software. Software can read the register ECAP\_STATUS to get the status of flags and has to write 1 to the corresponding bit(s) of ECAP\_STATUS to clear flag(s).

In addition, setting the CAPxCLREN(ECAP\_CTL1[22:20]) will allow hardware to reset capture counter (ECAP\_CNT) automatically whenever the event happens.

### Compare Mode

The compare function is enabled by setting the CMPEN (ECAP\_CTL0[28]) bit to 1, and ECAP\_CNTCMP will serve as a compare register. As ECAP\_CNT counting up, upon matching ECAP\_CNTCMP value, the flag, CAPCMF (ECAP\_STATUS[4]), will be set, which will generate an interrupt, CMP\_INT, if compare interrupt enable bit, CMPIEN (ECAP\_CTL0[21]), is set.

Besides, setting the CMPCLR (ECAP\_CTL0[25]) will allow hardware to make capture counter cleared to 0 automatically after a compare-match event occurs.

### Reload Mode

The Input Capture Timer/Counter can also be configured for reload mode. The reload function is enabled by setting the RLDEN[3:0] bits (ECAP\_CTL1[11:8]) – OVRLDEN, CAPxRLDEN – to 1, and each bit enables a reload source.

In this mode, ECAP\_CNTCMP serves as a reload register. If OVRLDEN is set, a reload event is generated and causes the content of the ECAP\_CNTCMP register to be loaded into the ECAP\_CNT register when ECAP\_CNT overflows. Furthermore, CAPxRLDEN, x=0~2, are enable bits of making CAPTE2 ~ CAPTE0 as reload sources.

One thing should be noted is that if CAPxCLREN as well as CAPxRLDEN are set, when a valid trigger event (CAPTE<sub>x</sub>) occurs, only RELAOD function will be executed.

#### 6.14.5.3 Input Capture Timer/Counter Interrupt Architecture

Figure 6.14-5 demonstrates the architecture of Input Capture Timer/Counter interrupt module. There are 5 interrupt sources (OVF\_INT, CMP\_INT, CAPTF0\_INT~CAPTF2\_INT), which are logical ‘OR’ together, in a input capture unit, and each one has an interrupt flag (CAPOVF, CAPCMF, CAPTF0~CAPTF2), which can trigger Interrupt (ECAP\_INT), as well as an the enable control bit (OVIEN, CMPIEN, CAPIEN0~CAPIEN2) to enable/disable the flag.

Note that all the interrupt flags are set by hardware and must be cleared by software by writing 1 to the bit (ECAP\_STATUS[5:4],[2:0]) corresponding to the flag.



Figure 6.14-5 Input Capture Timer/Counter Interrupt Architecture Diagram

### 6.14.6 Register Map

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

| Register                                   | Offset         | R/W | Description                               | Reset Value |
|--------------------------------------------|----------------|-----|-------------------------------------------|-------------|
| <b>ECAP Base Address:</b>                  |                |     |                                           |             |
| ECAPn_BA = 0x400B_4000 + (0x0000_1000 * n) |                |     |                                           |             |
| n=0, 1                                     |                |     |                                           |             |
| <b>ECAP_CNT</b>                            | ECAPn_BA+0x00  | R/W | Input Capture Counter (24-bit up counter) | 0x0000_0000 |
| <b>ECAP_HLD0</b>                           | ECAPn_BA+0x04  | R/W | Input Capture Hold Register 0             | 0x0000_0000 |
| <b>ECAP_HLD1</b>                           | ECAPn_BA+0x08  | R/W | Input Capture Hold Register 1             | 0x0000_0000 |
| <b>ECAP_HLD2</b>                           | ECAPn_BA+0x0C  | R/W | Input Capture Hold Register 2             | 0x0000_0000 |
| <b>ECAP_CNTCMP</b>                         | ECAPn_BA+0x10  | R/W | Input Capture Compare Register            | 0x0000_0000 |
| <b>ECAP_CTL0</b>                           | ECAPn_BA+0x14  | R/W | Input Capture Control Register 0          | 0x0000_0000 |
| <b>ECAP_CTL1</b>                           | ECAPn_BA+0x18  | R/W | Input Capture Control Register 1          | 0x0000_0000 |
| <b>ECAP_STATUS</b>                         | ECAPn_BA+0x1C  | R/W | Input Capture Status Register             | 0x0000_0000 |
| <b>ECAP_VERSION</b>                        | ECAPn_BA+0xFFC | R   | ECAP Version Control Register             | 0x0202_0000 |

### 6.14.7 Register Description

#### Input Capture Counter (ECAP\_CNT)

| Register | Offset        | R/W | Description                               |  |  |  | Reset Value |
|----------|---------------|-----|-------------------------------------------|--|--|--|-------------|
| ECAP_CNT | ECAPn_BA+0x00 | R/W | Input Capture Counter (24-bit up counter) |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                    |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                          |
| [23:0]  | CNT         | <b>Input Capture Timer/Counter</b><br>The input Capture Timer/Counter is a 24-bit up-counting counter. The clock source for the counter is from the clock divider. |

**Input Capture Counter Hold Register (ECAP\_HLD0~2)**

| Register         | Offset        | R/W | Description                   |  |  |  | Reset Value |
|------------------|---------------|-----|-------------------------------|--|--|--|-------------|
| <b>ECAP_HLD0</b> | ECAPn_BA+0x04 | R/W | Input Capture Hold Register 0 |  |  |  | 0x0000_0000 |
| <b>ECAP_HLD1</b> | ECAPn_BA+0x08 | R/W | Input Capture Hold Register 1 |  |  |  | 0x0000_0000 |
| <b>ECAP_HLD2</b> | ECAPn_BA+0x0C | R/W | Input Capture Hold Register 2 |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                          |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                |
| [23:0]  | <b>HOLD</b>     | <b>Input Capture Counter Hold Register</b><br>When an active input capture channel detects a valid edge signal change, the ECAPCNT value is latched into the corresponding holding register. Each input channel has its own holding register named by ECAP_HLDx where x is from 0 to 2 to indicate inputs from IC0 to IC2, respectively. |

**Input Capture Counter Compare Register (ECAP\_CNTCMP)**

| Register           | Offset        | R/W | Description                    |  |  |  | Reset Value |
|--------------------|---------------|-----|--------------------------------|--|--|--|-------------|
| <b>ECAP_CNTCMP</b> | ECAPn_BA+0x10 | R/W | Input Capture Compare Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                    |
| [23:0]  | <b>CNTCMP</b>   | <p><b>Input Capture Counter Compare Register</b></p> <p>If the compare function is enabled (CMPEN = 1), this register (ECAP_CNTCMP) is used to compare with the capture counter (ECAP_CNT).</p> <p>If the reload control is enabled (RLDEN[n] = 1, n=0~3), an overflow event or capture events will trigger the hardware to load the value of this register (ECAP_CNTCMP) into ECAP_CNT.</p> |

**Input Capture Timer/Counter Control Register (ECAP\_CTL0)**

| Register  | Offset        | R/W | Description                      |  |  | Reset Value |
|-----------|---------------|-----|----------------------------------|--|--|-------------|
| ECAP_CTL0 | ECAPn_BA+0x14 | R/W | Input Capture Control Register 0 |  |  | 0x0000_0000 |

|          |       |         |       |          |          |          |         |
|----------|-------|---------|-------|----------|----------|----------|---------|
| 31       | 30    | 29      | 28    | 27       | 26       | 25       | 24      |
| Reserved |       | CAPEN   | CMPEN | Reserved |          | CMPCLREN | CNTEN   |
| 23       | 22    | 21      | 20    | 19       | 18       | 17       | 16      |
| Reserved |       | CMPIEN  | OVIEN | Reserved | CAPIEN2  | CAPIEN1  | CAPIEN0 |
| 15       | 14    | 13      | 12    | 11       | 10       | 9        | 8       |
| Reserved |       | CAPSEL2 |       | CAPSEL1  |          | CAPSEL0  |         |
| 7        | 6     | 5       | 4     | 3        | 2        | 1        | 0       |
| Reserved | IC2EN | IC1EN   | IC0EN | CAPNFDIS | NFCLKSEL |          |         |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                               |
| [29]    | CAPEN       | <b>Input Capture Timer/Counter Enable Bit</b><br>0 = Input Capture function Disabled.<br>1 = Input Capture function Enabled.                                                                                                                                                                                                                                            |
| [28]    | CMPEN       | <b>Compare Function Enable Bit</b><br>The compare function in input capture timer/counter is to compare the dynamic counting ECAP_CNT with the compare register ECAP_CNTCMP, if ECAP_CNT value reaches ECAP_CNTCMP, the flag CAPCMPF will be set.<br>0 = The compare function Disabled.<br>1 = The compare function Enabled.                                            |
| [25]    | CMPCLREN    | <b>Input Capture Counter Cleared by Compare-match Control</b><br>If this bit is set to 1, the capture counter (ECAP_CNT) will be cleared to 0 when the compare-match event (CAPCMPF = 1) occurs.<br>0 = Compare-match event (CAPCMPF) can clear capture counter (ECAP_CNT) Disabled.<br>1 = Compare-match event (CAPCMPF) can clear capture counter (ECAP_CNT) Enabled. |
| [24]    | CNTEN       | <b>Input Capture Counter Start Counting Control</b><br>Setting this bit to 1, the capture counter (ECAP_CNT) starts up-counting synchronously with the clock from the .<br>0 = ECAP_CNT stop counting.<br>1 = ECAP_CNT starts up-counting.                                                                                                                              |
| [23:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                               |
| [21]    | CMPIEN      | <b>CAPCMPF Trigger Input Capture Interrupt Enable Bit</b><br>0 = The flag CAPCMPF can trigger Input Capture interrupt Disabled.<br>1 = The flag CAPCMPF can trigger Input Capture interrupt Enabled.                                                                                                                                                                    |
| [20]    | OVIEN       | <b>CAPOVF Trigger Input Capture Interrupt Enable Bit</b><br>0 = The flag CAPOVF can trigger Input Capture interrupt Disabled.<br>1 = The flag CAPOVF can trigger Input Capture interrupt Enabled.                                                                                                                                                                       |

| Bits    | Description     |                                                                                                                                                                                                                                                     |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                           |
| [18]    | <b>CAPIEN2</b>  | <b>Input Capture Channel 2 Interrupt Enable Bit</b><br>0 = The flag CAPTF2 can trigger Input Capture interrupt Disabled.<br>1 = The flag CAPTF2 can trigger Input Capture interrupt Enabled.                                                        |
| [17]    | <b>CAPIEN1</b>  | <b>Input Capture Channel 1 Interrupt Enable Bit</b><br>0 = The flag CAPTF1 can trigger Input Capture interrupt Disabled.<br>1 = The flag CAPTF1 can trigger Input Capture interrupt Enabled.                                                        |
| [16]    | <b>CAPIEN0</b>  | <b>Input Capture Channel 0 Interrupt Enable Bit</b><br>0 = The flag CAPTF0 can trigger Input Capture interrupt Disabled.<br>1 = The flag CAPTF0 can trigger Input Capture interrupt Enabled.                                                        |
| [15:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                           |
| [13:12] | <b>CAPSEL2</b>  | <b>CAP2 Input Source Selection</b><br>00 = CAP2 input is from port pin ICAP2.<br>01 = Reserved.<br>10 = CAP2 input is from signal CHX of QEI controller unit n.<br>11 = Reserved.<br><b>Note:</b> Input capture unit n matches QEIn, where n = 0~1. |
| [11:10] | <b>CAPSEL1</b>  | <b>CAP1 Input Source Selection</b><br>00 = CAP1 input is from port pin ICAP1.<br>01 = Reserved.<br>10 = CAP1 input is from signal CHB of QEI controller unit n.<br>11 = Reserved.<br><b>Note:</b> Input capture unit n matches QEIn, where n = 0~1. |
| [9:8]   | <b>CAPSEL0</b>  | <b>CAP0 Input Source Selection</b><br>00 = CAP0 input is from port pin ICAP0.<br>01 = Reserved.<br>10 = CAP0 input is from signal CHA of QEI controller unit n.<br>11 = Reserved.<br><b>Note:</b> Input capture unit n matches QEIn, where n = 0~1. |
| [7]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                           |
| [6]     | <b>IC2EN</b>    | <b>Port Pin IC2 Input to Input Capture Unit Enable Bit</b><br>0 = IC2 input to Input Capture Unit Disabled.<br>1 = IC2 input to Input Capture Unit Enabled.                                                                                         |
| [5]     | <b>IC1EN</b>    | <b>Port Pin IC1 Input to Input Capture Unit Enable Bit</b><br>0 = IC1 input to Input Capture Unit Disabled.<br>1 = IC1 input to Input Capture Unit Enabled.                                                                                         |
| [4]     | <b>IC0EN</b>    | <b>Port Pin IC0 Input to Input Capture Unit Enable Bit</b><br>0 = IC0 input to Input Capture Unit Disabled.<br>1 = IC0 input to Input Capture Unit Enabled.                                                                                         |
| [3]     | <b>CAPNFDIS</b> | <b>Input Capture Noise Filter Disable Bit</b><br>0 = Noise filter of Input Capture Enabled.<br>1 = Noise filter of Input Capture Disabled (Bypass).                                                                                                 |

| Bits  | Description                                                                                                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2:0] | <b>NFCLKSEL</b><br><b>Noise Filter Clock Pre-divide Selection</b><br>To determine the sampling frequency of the Noise Filter clock<br>000 = CAP_CLK.<br>001 = CAP_CLK/2.<br>010 = CAP_CLK/4.<br>011 = CAP_CLK/16.<br>100 = CAP_CLK/32.<br>101 = CAP_CLK/64. |

**Input Capture Timer/Counter Control Register (ECAP\_CTL1)**

| Register  | Offset        | R/W | Description                      |  |  |  | Reset Value |
|-----------|---------------|-----|----------------------------------|--|--|--|-------------|
| ECAP_CTL1 | ECAPn_BA+0x18 | R/W | Input Capture Control Register 1 |  |  |  | 0x0000_0000 |

|          |           |           |           |          |           |           |           |
|----------|-----------|-----------|-----------|----------|-----------|-----------|-----------|
| 31       | 30        | 29        | 28        | 27       | 26        | 25        | 24        |
| Reserved |           |           |           |          |           |           |           |
| 23       | 22        | 21        | 20        | 19       | 18        | 17        | 16        |
| Reserved | CAP2CLREN | CAP1CLREN | CAP0CLREN | Reserved |           | CNTSRCSEL |           |
| 15       | 14        | 13        | 12        | 11       | 10        | 9         | 8         |
| Reserved | CLKSEL    |           |           | OVRLDEN  | CAP2RLDEN | CAP1RLDEN | CAP0RLDEN |
| 7        | 6         | 5         | 4         | 3        | 2         | 1         | 0         |
| Reserved |           | EDGESEL2  |           | EDGESEL1 |           | EDGESEL0  |           |

| Bits    | Description |                                                                                                                                                                                               |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                     |
| [22]    | CAP2CLREN   | <b>Capture Counter Cleared by Capture Event2 Control</b><br>0 = Event CAPTE2 can clear capture counter (ECAP_CNT) Disabled.<br>1 = Event CAPTE2 can clear capture counter (ECAP_CNT) Enabled. |
| [21]    | CAP1CLREN   | <b>Capture Counter Cleared by Capture Event1 Control</b><br>0 = Event CAPTE1 can clear capture counter (ECAP_CNT) Disabled.<br>1 = Event CAPTE1 can clear capture counter (ECAP_CNT) Enabled. |
| [20]    | CAP0CLREN   | <b>Capture Counter Cleared by Capture Event0 Control</b><br>0 = Event CAPTE0 can clear capture counter (ECAP_CNT) Disabled.<br>1 = Event CAPTE0 can clear capture counter (ECAP_CNT) Enabled. |
| [17:16] | CNTSRCSEL   | <b>Capture Timer/Counter Clock Source Selection</b><br>Select the capture timer/counter clock source.<br>00 = CAP_CLK (default).<br>01 = CAP0.<br>10 = CAP1.<br>11 = CAP2.                    |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                     |

| Bits    | Description                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [14:12] | <b>CLKSEL</b><br><b>Capture Timer Clock Divide Selection</b><br>The capture timer clock has a pre-divider with eight divided options controlled by CLKSEL[2:0].<br>000 = CAP_CLK/1.<br>001 = CAP_CLK/4.<br>010 = CAP_CLK/16.<br>011 = CAP_CLK/32.<br>100 = CAP_CLK/64.<br>101 = CAP_CLK/96.<br>110 = CAP_CLK/112.<br>111 = CAP_CLK/128. |
| [11]    | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                         |
| [11]    | <b>OVRLDEN</b><br><b>Capture Counter's Reload Function Triggered by Overflow Enable Bit</b><br>0 = The reload triggered by CAPOV Disabled.<br>1 = The reload triggered by CAPOV Enabled.                                                                                                                                                |
| [10]    | <b>CAP2RLDEN</b><br><b>Capture Counter's Reload Function Triggered by Event CAPTE2 Enable Bit</b><br>0 = The reload triggered by Event CAPTE2 Disabled.<br>1 = The reload triggered by Event CAPTE2 Enabled.                                                                                                                            |
| [9]     | <b>CAP1RLDEN</b><br><b>Capture Counter's Reload Function Triggered by Event CAPTE1 Enable Bit</b><br>0 = The reload triggered by Event CAPTE1 Disabled.<br>1 = The reload triggered by Event CAPTE1 Enabled.                                                                                                                            |
| [8]     | <b>CAP0RLDEN</b><br><b>Capture Counter's Reload Function Triggered by Event CAPTE0 Enable Bit</b><br>0 = The reload triggered by Event CAPTE0 Disabled.<br>1 = The reload triggered by Event CAPTE0 Enabled.                                                                                                                            |
| [7:6]   | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                         |
| [5:4]   | <b>EDGESEL2</b><br><b>Channel 2 Captured Edge Selection</b><br>Input capture2 can detect falling edge change only, rising edge change only or both edge changes<br>00 = Detect rising edge only.<br>01 = Detect falling edge only.<br>1x = Detect both rising and falling edge.                                                         |
| [3:2]   | <b>EDGESEL1</b><br><b>Channel 1 Captured Edge Selection</b><br>Input capture1 can detect falling edge change only, rising edge change only or both edge change<br>00 = Detect rising edge only.<br>01 = Detect falling edge only.<br>1x = Detect both rising and falling edge.                                                          |

| Bits  | Description                                                                                                                                                                                                                                                                 |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0] | <b>EDGESEL0</b><br><br>Channel 0 Captured Edge Selection<br>Input capture0 can detect falling edge change only, rising edge change only or both edge change<br>00 = Detect rising edge only.<br>01 = Detect falling edge only.<br>1x = Detect both rising and falling edge. |

**Input Capture Timer/Counter Status Register (ECAP\_STATUS)**

| Register           | Offset        | R/W | Description                   |  |  |  | Reset Value |
|--------------------|---------------|-----|-------------------------------|--|--|--|-------------|
| <b>ECAP_STATUS</b> | ECAPn_BA+0x1C | R/W | Input Capture 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 |    |        |          |          | CAP2   | CAP1   | CAP0   |
| 7        | 6  | 5      | 4        | 3        | 2      | 1      | 0      |
| Reserved |    | CAPOVF | CAPCMPPF | Reserved | CAPTF2 | CAPTF1 | CAPTF0 |

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                            |
| [10]    | <b>CAP2</b>     | <b>Value of Input Channel 2, CAP2 (Read Only)</b><br>Reflecting the value of input channel 2, CAP2.<br>(The bit is read only and write is ignored)                                                                                                                                                                                                                                                                   |
| [9]     | <b>CAP1</b>     | <b>Value of Input Channel 1, CAP1 (Read Only)</b><br>Reflecting the value of input channel 1, CAP1<br>(The bit is read only and write is ignored)                                                                                                                                                                                                                                                                    |
| [8]     | <b>CAP0</b>     | <b>Value of Input Channel 0, CAP0 (Read Only)</b><br>Reflecting the value of input channel 0, CAP0<br>(The bit is read only and write is ignored)                                                                                                                                                                                                                                                                    |
| [7:6]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                            |
| [5]     | <b>CAPOVF</b>   | <b>Input Capture Counter Overflow Flag</b><br>Flag is set by hardware when counter (ECAP_CNT) overflows from 0x00FF_FFFF to 0.<br>0 = No overflow event has occurred since last clear.<br>1 = Overflow event(s) has/have occurred since last clear.<br><b>Note:</b> This bit is only cleared by writing 1 to it.                                                                                                     |
| [4]     | <b>CAPCMPPF</b> | <b>Input Capture Compare-match Flag</b><br>If the input capture compare function is enabled, the flag is set by hardware when capture counter (ECAP_CNT) up counts and reaches the ECAP_CNTCMP value.<br>0 = ECAP_CNT has not matched ECAP_CNTCMP value since last clear.<br>1 = ECAP_CNT has matched ECAP_CNTCMP value at least once since last clear.<br><b>Note:</b> This bit is only cleared by writing 1 to it. |
| [3]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                            |

| Bits | Description   |                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2]  | <b>CAPTF2</b> | <b>Input Capture Channel 2 Triggered Flag</b><br>When the input capture channel 2 detects a valid edge change at CAP2 input, it will set flag CAPTF2 to high.<br>0 = No valid edge change has been detected at CAP2 input since last clear.<br>1 = At least a valid edge change has been detected at CAP2 input since last clear.<br><b>Note:</b> This bit is only cleared by writing 1 to it. |
| [1]  | <b>CAPTF1</b> | <b>Input Capture Channel 1 Triggered Flag</b><br>When the input capture channel 1 detects a valid edge change at CAP1 input, it will set flag CAPTF1 to high.<br>0 = No valid edge change has been detected at CAP1 input since last clear.<br>1 = At least a valid edge change has been detected at CAP1 input since last clear.<br><b>Note:</b> This bit is only cleared by writing 1 to it. |
| [0]  | <b>CAPTF0</b> | <b>Input Capture Channel 0 Triggered Flag</b><br>When the input capture channel 0 detects a valid edge change at CAP0 input, it will set flag CAPTF0 to high.<br>0 = No valid edge change has been detected at CAP0 input since last clear.<br>1 = At least a valid edge change has been detected at CAP0 input since last clear.<br><b>Note:</b> This bit is only cleared by writing 1 to it. |

**ECAP Version Control Register (ECAP\_VERSION)**

| Register            | Offset         | R/W | Description                   |  |  |  | Reset Value |
|---------------------|----------------|-----|-------------------------------|--|--|--|-------------|
| <b>ECAP_VERSION</b> | ECAPn_BA+0xFFC | R   | ECAP Version Control Register |  |  |  | 0x0202_0000 |

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

| Bits    | Description  |                                                                                                                                                                                               |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <b>MAJOR</b> | <b>ECAP RTL Design MAJOR Version Number</b><br>Major version number is correlated to Product Line<br>0x02: (current Major Version Number)                                                     |
| [23:16] | <b>SUB</b>   | <b>ECAP RTL Design SUB Version Number</b><br>Sub version number is relative to key feature<br>0x02: (current Sub Version Number) – RLD sources can be separately controlled, the same to CLR. |
| [15:0]  | <b>MINOR</b> | <b>ECAP RTL Design MINOR Version Number</b><br>Minor version number is dependent on ECO version control<br>0x0000: (current Minor Version Number)                                             |

## 6.15 UART Interface Controller (UART)

### 6.15.1 Overview

The chip provides six channels of Universal Asynchronous Receiver/Transmitters (UART). The UART controller performs Normal Speed UART and supports flow control function. The UART controller performs a serial-to-parallel conversion on data received from the peripheral and a parallel-to-serial conversion on data transmitted from the CPU. Each UART controller channel supports ten types of interrupts. The UART controller also supports IrDA SIR, LIN and RS-485 function modes and auto-baud rate measuring function.

### 6.15.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 UART0 /UART1 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

| UART Feature                                 | UART0/ UART1    | UART2/<br>UART4/ UART5 | UART3/<br>UART5 | SC_UART                | USCI-UART |
|----------------------------------------------|-----------------|------------------------|-----------------|------------------------|-----------|
| FIFO                                         | 16 Bytes        | 16 Bytes               | 4 Bytes         | TX: 1byte<br>RX: 2byte |           |
| Auto Flow Control (CTS/RTS)                  | √               | √                      | -               | √                      |           |
| IrDA                                         | √               | √                      | -               | -                      |           |
| LIN                                          | √               | -                      | -               | -                      |           |
| RS-485 Function Mode                         | √               | √                      | -               | √                      |           |
| nCTS Wake-up                                 | √               | √                      | -               | √                      |           |
| Imcoming Data Wake-up                        | √               | √                      | -               | √                      |           |
| Received Data FIFO reached threshold Wake-up | √               | √                      | -               | -                      |           |
| RS-485 Address Match (AAD mode) Wake-up      | √               | √                      | -               | -                      |           |
| Auto-Baud Rate Measurement                   | √               | √                      | -               | √                      |           |
| STOP Bit Length                              | 1, 1.5, 2 bit   | 1, 1.5, 2 bit          | 1, 2 bit        | 1, 2 bit               |           |
| Word Length                                  | 5, 6, 7, 8 bits | 5, 6, 7, 8 bits        | 5, 6, 7, 8 bits | 6~13 bits              |           |
| Even / Odd Parity                            | √               | √                      | √               | √                      |           |
| Stick Bit                                    | √               | √                      | -               | -                      |           |
| <b>Note:</b> √= Supported                    |                 |                        |                 |                        |           |

Table 6.15-1 NuMicro® M480 Series UART Features

### 6.15.3 Block Diagram

The UART clock control and block diagram are shown in Figure 6.15-1 and Figure 6.15-2 respectively.

**Note:** The frequency of UARTx\_CLK should not be greater than 30 times HCLK.



Figure 6.15-1 UART Clock Control Diagram



Figure 6.15-2 UART Block Diagram

Each block is described in detail as follows:

#### **TX\_FIFO**

The transmitter is buffered with a 16 bytes FIFO to reduce the number of interrupts presented to the CPU.

#### **RX\_FIFO**

The receiver is buffered with a 16 bytes FIFO (plus three error bits, BIF (UART\_FIFOSTS[6]), FEF (UART\_FIFOSTS[5]), PEF (UART\_FIFOSTS[4])) to reduce the number of interrupts presented to the CPU.

#### **TX Shift Register**

This block is responsible for shifting out the transmitting data serially.

#### **RX Shift Register**

This block is responsible for shifting in the receiving data serially.

#### **Modem Control and Status Register**

This register controls the interface to the MODEM or data set (or a peripheral device emulating a MODEM).

#### **Baud Rate Generator**

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

#### **IrDA Encode**

This block is IrDA encoding control block.

#### **IrDA Decode**

This block is IrDA decoding control block.

#### **FIFO & Line Control and Status Register**

This field is register set that including the FIFO control register (UART\_FIFO), FIFO status register (UART\_FIFOSTS), and line control register (UART\_LINE) for transmitter and receiver. The time-out register (UART\_TOUT) identifies the condition of time-out interrupt.

#### Auto-Baud Rate Measurement

This block is responsible for auto-baud rate measurement.

#### Interrupt Control and Status Register

There are ten types of interrupts, Receive Data Available Interrupt (RDAINT), Transmit Holding Register Empty Interrupt (THERINT), Transmitter Empty Interrupt (TXENDINT), Receive Line Status Interrupt (parity error or framing error or break interrupt) (RLSINT), MODEM Status Interrupt (MODEMINT), Receiver Buffer Time-out Interrupt (RXTOINT), Buffer Error Interrupt (BUFERRINT), LIN Bus Interrupt (LININT), Wake-up Interrupt (WKINT) and Auto-Baud Rate Interrupt (ABRINT). Interrupt enable register (UART\_INTEN) enable or disable the responding interrupt and interrupt status register (UART\_INTSTS) identifying the occurrence of the responding interrupt.

| Interrupt | Description                                                                 |
|-----------|-----------------------------------------------------------------------------|
| RDAINT    | Receive Data Available Interrupt.                                           |
| THERINT   | Transmit Holding Register Empty Interrupt.                                  |
| TXENDINT  | Transmitter Empty Interrupt.                                                |
| RLSINT    | Receive Line Status Interrupt (parity error or frame error or break error). |
| MODEMINT  | MODEM Status Interrupt.                                                     |
| RXTOINT   | Receiver Buffer Time-out Interrupt.                                         |
| BUFERRINT | Buffer Error Interrupt.                                                     |
| LININT    | LIN Bus Interrupt.                                                          |
| WKINT     | Wake-up Interrupt.                                                          |
| ABRINT    | Auto-Baud Rate Interrupt.                                                   |

Table 6.15-2 UART Interrupt

#### 6.15.4 Basic Configuration

The basic configurations of UART0 are as follows:

- Clock Source Configuration
  - Select the source of UART0 peripheral clock on UART0SEL (CLK\_CLKSEL1[25:24]).
  - Select the clock divider number of UART0 peripheral clock on UART0DIV (CLK\_CLKDIV0[11:8]).
  - Enable UART0 peripheral clock in UART0CKEN (CLK\_APBCLK1[16]).
- Reset UART0 controller in UART0RST (SYS\_IPRST1[16]).
- Pin Configuration

| Group | Pin Name  | GPIO               | MFP  |
|-------|-----------|--------------------|------|
| UART0 | UART0_RXD | PA.15, PC.11, PF.2 | MFP3 |
|       |           | PB.8               | MFP5 |
|       |           | PB.12              | MFP6 |
|       |           | PA.0, PA.6         | MFP7 |

|            |                    |      |
|------------|--------------------|------|
| UART0_TXD  | PH.11              | MFP8 |
|            | PD.2               | MFP9 |
|            | PA.14, PC.12, PF.3 | MFP3 |
|            | PB.9               | MFP5 |
|            | PB.13              | MFP6 |
|            | PA.1, PA.7         | MFP7 |
|            | PH.10              | MFP8 |
|            | PD.3               | MFP9 |
|            | PB.11              | MFP5 |
|            | PB.15              | MFP6 |
| UART0_nCTS | PA.5, PC.7         | MFP7 |
|            | PB.10              | MFP5 |
|            | PB.14              | MFP6 |
| UART0_nRTS | PA.4, PC.6         | MFP7 |

The basic configurations of UART1 are as follows:

- Clock Source Configuration
  - Select the source of UART1 peripheral clock on UART1SEL (CLK\_CLKSEL1[27:26]).
  - Select the clock divider number of UART1 peripheral clock on UART1DIV (CLK\_CLKDIV0[15:12]).
  - Enable UART1 peripheral clock in UART1CKEN (CLK\_APBCLK1[17]).
- Reset UART1 controller in UART1RST (SYS\_IPRST1[17]).
- Pin Configuration

| Group | Pin Name   | GPIO              | MFP   |
|-------|------------|-------------------|-------|
| UART1 | UART1_RXD  | PF.1              | MFP2  |
|       |            | PD.6, PD.10       | MFP3  |
|       |            | PB.2, PB.6        | MFP6  |
|       |            | PA.8              | MFP7  |
|       |            | PA.2, PC.8, PG.1  | MFP8  |
|       |            | PH.9              | MFP10 |
|       | UART1_TXD  | PF.0              | MFP2  |
|       |            | PD.7, PD.11       | MFP3  |
|       |            | PB.3, PB.7        | MFP6  |
|       |            | PA.9              | MFP7  |
|       |            | PA.3, PE.13, PG.0 | MFP8  |
|       |            | PH.8              | MFP10 |
|       | UART1_nCTS | PB.9              | MFP6  |

|  |            |             |      |
|--|------------|-------------|------|
|  |            | PA.1, PE.11 | MFP8 |
|  | UART1_nRTS | PB.8        | MFP6 |
|  |            | PA.0, PE.12 | MFP8 |

The basic configurations of UART2 are as follows:

- Clock Source Configuration
  - Select the source of UART2 peripheral clock on UART2SEL (CLK\_CLKSEL3[25:24]).
  - Select clock divider number of UART2 peripheral clock on UART2DIV (CLK\_CLKDIV4[3:0]).
  - Enable UART2 peripheral clock in UART2CKEN (CLK\_APBCLK1[18]).
- Reset UART2 controller in UART2RST (SYS\_IPRST1[18]).
- Pin Configuration

| Group | Pin Name   | GPIO              | MFP  |
|-------|------------|-------------------|------|
| UART2 | UART2_RXD  | PF.5              | MFP2 |
|       |            | PE.15             | MFP3 |
|       |            | PG.0              | MFP6 |
|       |            | PB.0, PD.12, PE.9 | MFP7 |
|       |            | PC.0, PC.4        | MFP8 |
|       | UART2_TXD  | PF.4              | MFP2 |
|       |            | PE.14             | MFP3 |
|       |            | PG.1              | MFP6 |
|       |            | PB.1, PC.13, PE.8 | MFP7 |
|       |            | PC.1, PC.5        | MFP8 |
|       | UART2_nCTS | PD.9, PF.5        | MFP4 |
|       |            | PC.2              | MFP8 |
|       | UART2_nRTS | PD.8, PF.4        | MFP4 |
|       |            | PC.3              | MFP8 |

The basic configurations of UART3 are as follows:

- Clock Source Configuration
  - Select the source of UART3 peripheral clock on UART3SEL (CLK\_CLKSEL3[27:26]).
  - Select the clock divider number of UART3 peripheral clock on UART3DIV (CLK\_CLKDIV4[7:4]).
  - Enable UART3 peripheral clock in UART3CKEN (CLK\_APBCLK1[19]).
- Reset UART3 controller in UART3RST (SYS\_IPRST1[19]).
- Pin Configuration

| Group | Pin Name  | GPIO | MFP  |
|-------|-----------|------|------|
| UART3 | UART3_RXD | PD.0 | MFP5 |

|  |            |                           |       |
|--|------------|---------------------------|-------|
|  | UART3_TXD  | PB.14, PC.9, PE.0, PE.11  | MFP7  |
|  |            | PC.2                      | MFP11 |
|  |            | PD.1                      | MFP5  |
|  |            | PB.15, PC.10, PE.1, PE.10 | MFP7  |
|  | UART3_nCTS | PC.3                      | MFP11 |
|  |            | PD.2                      | MFP5  |
|  | UART3_nRTS | PB.12, PH.9               | MFP7  |
|  |            | PD.3                      | MFP5  |
|  |            | PB.13, PH.8               | MFP7  |

The basic configurations of UART4 are as follows:

- Clock Source Configuration
  - Select the source of UART4 peripheral clock on UART4SEL (CLK\_CLKSEL3[29:28]).
  - Select the clock divider number of UART4 peripheral clock on UART4DIV (CLK\_CLKDIV4[11:8]).
  - Enable UART4 peripheral clock in UART4CKEN (CLK\_APBCLK1[20]).
- Reset UART4 controller in UART4RST (SYS\_IPRST1[20]).
- Pin Configuration

| Group | Pin Name   | GPIO        | MFP   |
|-------|------------|-------------|-------|
| UART4 | UART4_RXD  | PA.13       | MFP3  |
|       |            | PC.6, PH.3  | MFP5  |
|       |            | PB.10, PF.6 | MFP6  |
|       |            | PA.2, PH.11 | MFP7  |
|       |            | PC.4        | MFP11 |
|       | UART4_TXD  | PA.12       | MFP3  |
|       |            | PC.7, PH.2  | MFP5  |
|       |            | PB.11, PF.7 | MFP6  |
|       |            | PA.3, PH.10 | MFP7  |
|       |            | PC.5        | MFP11 |
|       | UART4_nCTS | PC.8        | MFP5  |
|       |            | PE.1        | MFP9  |
|       | UART4_nRTS | PE.13       | MFP5  |
|       |            | PE.0        | MFP9  |

The basic configurations of UART5 are as follows:

- Clock Source Configuration
  - Select the source of UART5 peripheral clock on UART5SEL (CLK\_CLKSEL3[31:30]).
  - Select the clock divider number of UART5 peripheral clock on UART5DIV (CLK\_CLKDIV4[15:12]).

- Enable UART5 peripheral clock in UART5CKEN (CLK\_APBCLK1[21]).
- Reset UART5 controller in UART5RST (SYS\_IPRST1[21]).
- Pin Configuration

| Group | Pin Name   | GPIO       | MFP  |
|-------|------------|------------|------|
| UART5 | UART5_RXD  | PH.1       | MFP4 |
|       |            | PB.4       | MFP7 |
|       |            | PA.4, PE.6 | MFP8 |
|       | UART5_TXD  | PH.0       | MFP4 |
|       |            | PB.5       | MFP7 |
|       |            | PA.5, PE.7 | MFP8 |
|       | UART5_nCTS | PH.3       | MFP4 |
|       |            | PB.2       | MFP7 |
|       | UART5_nRTS | PH.2       | MFP4 |
|       |            | PB.3       | MFP7 |

UART Interface Controller Pin description is shown in Table 6.15-3:

| 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.15-3 UART Interface Controller Pin

### 6.15.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.15.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.15-4 list the UART baud rate equations in the various conditions. Table 6.15-5 and Table 6.15-6 list the UART baud rate parameter and register setting example. In IrDA function mode, the baud rate generator must be set in mode 0. More detail register description is shown in UART\_BAUD register. There are three setting mode. Mode 0 is set by UART\_BAUD[29:28] with 00. Mode 1 is set by UART\_BAUD[29:28] with 10. Mode 2 is set by UART\_BAUD[29:28] with 11.

| Mode   | BAUDM1 | BAUDM0 | Baud Rate Equation                                          |
|--------|--------|--------|-------------------------------------------------------------|
| Mode 0 | 0      | 0      | UART_CLK / [16 * (BRD+2)].                                  |
| Mode 1 | 1      | 0      | UART_CLK / [(EDIVM1+1) * (BRD+2)], EDIVM1 must >= 8.        |
| Mode 2 | 1      | 1      | UART_CLK / (BRD+2)<br>If UART_CLK <= 3*HCLK, BRD must >= 9. |

|  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | If $\text{UART\_CLK} > 3^*\text{HCLK}$ , $\text{BRD} \geq 3^*N - 1$ .<br>N is the smallest integer larger than or equal to the ratio of $\text{UART\_CLK} / \text{HCLK}$ .<br>For example,<br>if $3^*\text{HCLK} < \text{UART\_CLK} \leq 4^*\text{HCLK}$ , $\text{BRD} \geq 11$ .<br>if $4^*\text{HCLK} < \text{UART\_CLK} \leq 5^*\text{HCLK}$ , $\text{BRD} \geq 14$ .<br>(If the $\text{UART\_CLK}$ is selected from LXT, $\text{BRD}$ can be greater than or equal to 1) |
|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Table 6.15-4 UART controller Baud Rate Equation Table

| UART Peripheral Clock = 12 MHz |                  |                                    |                   |
|--------------------------------|------------------|------------------------------------|-------------------|
| Baud Rate                      | Mode 0           | Mode 1                             | Mode 2            |
| 921600                         | Not support      | Not recommended                    | $\text{BRD}=11$   |
| 460800                         | Not recommended  | $\text{BRD}=0, \text{EDIVM1}=13$   | $\text{BRD}=24$   |
| 230400                         | Not recommended  | $\text{BRD}=2, \text{EDIVM1}=13$   | $\text{BRD}=50$   |
| 115200                         | Not recommended  | $\text{BRD}=6, \text{EDIVM1}=13$   | $\text{BRD}=102$  |
| 57600                          | $\text{BRD}=11$  | $\text{BRD}=14, \text{EDIVM1}=13$  | $\text{BRD}=206$  |
| 38400                          | $\text{BRD}=18$  | $\text{BRD}=22, \text{EDIVM1}=13$  | $\text{BRD}=311$  |
| 19200                          | $\text{BRD}=37$  | $\text{BRD}=123, \text{EDIVM1}=5$  | $\text{BRD}=623$  |
| 9600                           | $\text{BRD}=76$  | $\text{BRD}=123, \text{EDIVM1}=10$ | $\text{BRD}=1248$ |
| 4800                           | $\text{BRD}=154$ | $\text{BRD}=248, \text{EDIVM1}=10$ | $\text{BRD}=2498$ |

Table 6.15-5 UART controller Baud Rate Parameter Setting Example Table

| UART Peripheral Clock = 12 MHz |                 |                 |             |
|--------------------------------|-----------------|-----------------|-------------|
| Baud Rate                      | UART_BAUD Value |                 |             |
|                                | Mode 0          | Mode 1          | Mode 2      |
| 921600                         | Not support     | Not recommended | 0x3000_000B |
| 460800                         | Not recommended | 0x2D00_0000     | 0x3000_0018 |
| 230400                         | Not recommended | 0x2D00_0002     | 0x3000_0032 |
| 115200                         | Not recommended | 0x2D00_0006     | 0x3000_0066 |
| 57600                          | 0x0000_000B     | 0x2D00_000E     | 0x3000_00CE |
| 38400                          | 0x0000_0012     | 0x2D00_0016     | 0x3000_0137 |
| 19200                          | 0x0000_0025     | 0x2500_007B     | 0x3000_026F |
| 9600                           | 0x0000_004C     | 0x2A00_007B     | 0x3000_04E0 |
| 4800                           | 0x0000_009A     | 0x2A00_00F8     | 0x3000_09C2 |

Table 6.15-6 UART controller Baud Rate Register Setting Example Table

#### 6.15.5.2 UART Controller Baud Rate Compensation

The UART controller supports baud rate compensation function. It is used to optimize the precision in each bit. The precision of the compensation is half of UART module clock because there is BRCOMDEC bit (UART\_BRCOMP[31]) to define the positive or negative compensation in each bit. If

the BRCOMPDEC (UART\_BRCOMP[31]) = 0, it is positive compensation for each bit, one more module clock will be append in the compensated bit. If the BRCOMPDEC (UART\_BRCOMP[31]) = 1, it is negative compensation for each bit, decrease one module clock in the compensated bit.

There is 9-bits location, BRCOMP[8:0] (UART\_BRCOMP[8:0]), can be configured by user to define the relative bit is compensated or not. BRCOMP[7:0] is used to define the compensation of UART\_DAT[7:0] and BRCOMP[8] is used to define the parity bit.

#### Example:

1. UART's peripheral clock = 32.768K and baud rate is 9600

Baud rate is 9600, UART peripheral clock is 32.768K → 3.413 peripheral clock/bit

if the baud divider is set 1 (3 peripheral clock/bit), the inaccuracy of each bit is -0.413 peripheral clock and BRCOMPDEC =0,

| Bit | Name        | Total INACCURACY     | BRCOMP 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.15-7 Baud Rate Compensation Example Table 1

So that the BRCOMP (UART\_BRCOMP[8:0]) can be set as 9'b010100101 = 0xa5.

2. UART's peripheral clock = 32.768K and baud rate is 4800

Baud rate is 4800, UART peripheral clock is 32.768K → 6.827 peripheral clock/bit

if the baud divider is set 5 (7 peripheral clock/bit), the inaccuracy of each bit is 0.173 peripheral clock and BRCOMPDEC =1,

| Bit | Name        | Total INACCURACY     | BRCOMP 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.15-8 Baud Rate Compensation Example Table 2

So that the BRCOMP (UART\_BRCOMP[8:0]) can be set as 9'b010000010 = 0x82.

#### 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 1st rising edge time is set by 2 ABRDBITS bit time in Auto-Baud Rate function detection frame.

2 ABRDBITS bit time from Start bit to the 1st rising edge is calculated by setting ABRDBITS (UART\_ALTCTL[20:19]). Setting ABRDEN (UART\_ALTCTL[18]) is to enable auto-baud rate function. In beginning stage, the UART RX is kept at 1. Once falling edge is detected, START bit is received. The auto-baud rate counter is reset and starts counting. The auto-baud rate counter will be stop when the 1 st rising edge is detected. Then, auto-baud rate counter value divided by ABRDBITS (UART\_ALTCTL[20:19]) is loaded to BRD (UART\_BAUD[15:0]) automatically. ABRDEN (UART\_ALTCTL[18]) is cleared. The Auto-Baud is shown in Figure 6.15-3. Once the auto-baud rate measurement is finished, the ABRDIF (UART\_FIFOSTS[1]) is set. When auto-baud rate counter is overflow, ABRDTOIF (UART\_FIFOSTS[2]) is set. ABRDIF (UART\_FIFOSTS[1]) or ABRDTOIF (UART\_FIFOSTS[2]) cause the auto-baud rate flag ABRIF(UART\_ALTCTL[17]) is generated. If the ABRIEN (UART\_INTEN[18]) is enabled, ABRIF(UART\_ALTCTL[17]) cause the auto-baud rate interrupt ABRINT (UART\_INTSTS[31]) is generated.



Figure 6.15-3 Auto-Baud Rate Measurement

#### Programming Sequence Example:

3. Program ABRDBITS (UART\_ALTCTL[20:19]) to determines UART RX data 1<sup>st</sup> rising edge

time from Start by  $2^{\text{ABRDBITS}}$  bit time.

4. Set ABRIEN (UART\_INTEN[18]) to enable auto-baud rate function interrupt.
5. Set ABRDEN (UART\_ALTCTL[18]) to enable auto-baud rate function.
6. ABRDIF (UART\_FIFOSTS[1]) is set, the auto-baud rate measurement is finished.
7. Operate UART transmit and receive action.
8. ABRDTOIF (UART\_FIFOSTS[2]) is set, if auto-baud rate counter is overflow.
9. Go to Step 3.

#### 6.15.5.3 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.15-4.



Figure 6.15-4 Transmit Delay Time Operation

#### 6.15.5.4 UART Controller FIFO Control and Status

The UART controller is built-in with a 16 bytes transmitter FIFO (TX\_FIFO) and a 16 bytes receiver FIFO (RX\_FIFO) that reduces the number of interrupts presented to the CPU. The CPU can read the status of the UART at any time during operation. The reported status information includes condition of the transfer operations being performed by the UART, as well as 3 error conditions (parity error, framing error, break interrupt) occur if receiving data has parity, frame or break error. UART, IrDA, LIN and RS-485 mode support FIFO control and status function.

#### 6.15.5.5 UART Controller Wake-up Function

The UART controller supports wake-up system function. The wake-up function includes nCTS pin, incoming data wake-up, Received Data FIFO reached threshold wake-up, RS-485 Address Match (AAD mode) wake-up and Received Data FIFO threshold time-out wake-up function. CTSWKF (UART\_WKSTS[0]), DATWKF (UART\_WKSTS[1]), RFRTWKF (UART\_WKSTS[2]), RS485WKF (UART\_WKSTS[3]) or TOUTWKF (UART\_WKSTS[4]) cause the wake-up interrupt flag WKIF(UART\_INTSTS[6]) is generated. If the WKIEN (UART\_INTEN[6]) is enabled, the wake-up interrupt flag WKIF(UART\_INTSTS[6]) cause the wake-up interrupt WKINT (UART\_INTSTS[14]) is generated.

nCTS pin wake-up :

When the system is in Power-down mode and WKCTSEN (UART\_WKCTL[0]) is set, the toggle of nCTS pin can wake-up system. If the WKCTSEN (UART\_WKCTL[0]) is enabled, the toggle of nCTS pin cause the nCTS wake-up flag CTSWKF (UART\_WKSTS[0]) is generated. The nCTS wake-up is shown in Figure 6.15-5 and Figure 6.15-6.

**nCTS Wake-up Case 1 (nCTS transition from low to high)**

**Note:** Stable count means HCLK source recovery stable count.

Figure 6.15-5 UART nCTS Wake-up Case1

**nCTS Wake-up Case 2 (nCTS transition from high to low)**

**Note:** Stable count means HCLK source recovery stable count.

Figure 6.15-6 UART nCTS Wake-up Case2

**Incoming Data Wake-up**

When system is in Power-down mode and the WKDATEN (UART\_WKCTL [1]) is set, the toggle of incoming data (UART\_RXD) pin can wake-up the system. In order to receive the incoming data after the system wake-up, the STCOMP (UART\_DWKCOMP[15:0]) shall be set. These bits field of STCOMP indicate how many clock cycle selected by UART\_CLK do the UART controller can get the 1<sup>st</sup> bit (start bit) when the system is wakeup from Power-down mode.

When incoming data wakes system up, the incoming data will be received and stored in FIFO. If the WKDATEN (UART\_WKCTL[1]) is enabled, the toggle of incoming data (UART\_RXD) pin cause the incoming data wake-up flag DATWKF (UART\_WKSTS[1]) is generated. The imcoing data wake-up is shown in Figure 6.15-7.

**Note1:** The UART controller clock source should be selected as HIRC and the compensation time for start bit is about 15.68us. It means that the value of STCOMP (UART\_DWKCOMP[15:0]) can be set as 347.

**Note2:** The value of BRD(UART\_BAUD[15:0]) should be greater than STCOMP (UART\_DWKCOMP[15:0]).



Figure 6.15-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 WKFRRTEN (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 WKFRRTEN (UART\_WKCTL[2]) is enabled, the number of received data in RX FIFO reaches the threshold value RFITL (UART\_FIFO[7:4]) cause the received data FIFO reached threshold wake-up flag RFRTWKF (UART\_WKSTS[2]) is generated. The Received Data FIFO reached threshold wake-up is shown in Figure 6.15-8.

**Note:** The UART controller clock source should be selected as LXT in Power-down mode to receive data.



Figure 6.15-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 WKFRRTEN (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]) that cause 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.15-9.

**Note:** The UART controller clock source should be selected as LXT in Power-down mode to receive data.



Figure 6.15-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]) that cause the Received Data FIFO threshold time-out wake-up wake-up flag TOUTWKF (UART\_WKSTS[4]) is generated. The Received Data FIFO threshold time-out wake-up is shown in Figure 6.15-10.

**Note:** The UART controller clock source should be selected as LXT in Power-down mode to receive data.



Figure 6.15-10 UART Received Data FIFO threshold time-out wake-up

#### 6.15.5.6 UART Controller Interrupt and Status

Each UART controller supports ten types of interrupts including:

- Receive Data Available Interrupt (RDAINT)
- Transmit Holding Register Empty Interrupt (THERINT)
- Transmitter Empty Interrupt (TXENDIF)
- Receive Line Status Interrupt (RLSINT)
  - Break Interrupt Flag (BIF)
  - Framing Error Flag (FEF)
  - Parity Error Flag (PEF)
  - RS-485 Address Byte Detect Flag (ADDRDETF)
- MODEM Status Interrupt (MODEMINT)
  - Detect nCTS State Change Flag (CTSDETF)
- Receiver Buffer Time-out Interrupt (RXTOINT)
- Buffer Error Interrupt (BUFERRINT)

- TX Overflow Error Interrupt Flag (TXOVIF)
- RX Overflow Error Interrupt Flag (RXOVIF)
- LIN Bus Interrupt (LININT)
  - LIN Break Detection Flag (BRKDETF)
  - Bit Error Detect Status Flag (BITEF)
  - LIN Slave ID Parity Error Flag (SLVIDPEF)
  - LIN Slave Header Error Flag (SLVHEF)
  - LIN Slave Header Detection Flag (SLVHDETF)
- Wake-up Interrupt (WKINT)
  - nCTS Wake-up Flag (CTSWKF)
  - Incoming Data Wake-up Flag (DATWKF)
  - Received Data FIFO Reached Threshold Wake-up Flag (RFRTWKF)
  - RS-485 Address Match (AAD mode) Wake-up Flag (RS485WKF)
  - Received Data FIFO Threshold Time-out Wake-up Flag (TOUTWKF)
- Auto-Baud Rate Interrupt (ABRINT)
  - Auto-baud Rate Detect Interrupt Flag (ABRDIF)
  - Auto-baud Rate Detect Time-out Interrupt Flag (ABRDTOIF)

Table 6.15-9 describes the interrupt sources and flags. The interrupt is generated when the interrupt flag is generated and the interrupt enable bit is set. User must clear the interrupt flag after the interrupt is generated.

| Interrupt Source                   | Interrupt Indicator | Interrupt Enable Bit | Interrupt Flag  | Flag Caused By                                                | Flag Cleared By                                                                   |
|------------------------------------|---------------------|----------------------|-----------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------|
| Receive Data Available Interrupt   | RDAINT              | RDAIEN               | <b>RDAIF</b>    | N/A                                                           | Read UART_DAT                                                                     |
| Transmit Register Empty Interrupt  | Holding THERINT     | THREIEN              | <b>THREIF</b>   | N/A                                                           | Write UART_DAT                                                                    |
| Transmitter Empty Interrupt        | Empty TXENDINT      | TXENDIEN             | <b>TXENDIF</b>  | N/A                                                           | Write UART_DAT                                                                    |
| Receive Line Status Interrupt      | Line RLSINT         | Status RLSIEN        | <b>RLSIF</b>    | RLSIF = BIF<br>RLSIF = FEF<br>RLSIF = PEF<br>RLSIF = ADDRDETF | Write '1' to BIF<br>Write '1' to FEF<br>Write '1' to PEF<br>Write '1' to ADDRDETF |
| Modem Status Interrupt             | MODEMINT            | MODEMIEN             | <b>MODEMIF</b>  | <b>MODEMIF</b><br>= CTSDETF                                   | Write '1' to CTSDETF                                                              |
| Receiver Buffer Time-out Interrupt | RXTOINT             | RXTOIEN              | <b>RXTOIF</b>   | N/A                                                           | Read UART_DAT                                                                     |
| Buffer Error Interrupt             | BUFERRINT           | BUFERRIEN            | <b>BUFERRIF</b> | BUFERRIF<br>= TXOVIF<br><br>BUFERRIF<br>= RXOVIF              | Write '1' to TXOVIF<br><br>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                          |                       |
|                        |        |        |        | WKIF = RFRTWKF   | Write '1' to RFRTWKF                         |                       |
|                        |        |        |        | WKIF = RS485WKF  | Write '1' to RS485WKF                        |                       |
|                        |        |        |        | WKIF = TOUTWKF   | Write '1' to TOUTWKF                         |                       |
| Auto-Baud<br>Interrupt | Rate   | ABRINT | ABRIEN | ABRIF            | ABRIF = ABRDIF                               | Write '1' to ABRDIF   |
|                        |        |        |        |                  | ABRIF = ABRDTOIF                             | Write '1' to ABRDTOIF |

Table 6.15-9 UART controller Interrupt Source and Flag List

#### 6.15.5.7 UART Function Mode

The UART controller provides UART function (Setting FUNCSEL (UART\_FUNCSEL [1:0]) to '00' to enable UART function mode). The UART baud rate is up to 1 Mbps.

The UART provides full-duplex and asynchronous communications. The transmitter and receiver contain 16 bytes FIFO for payloads. User can program receiver buffer trigger level and receiver buffer time-out detection for receiver. The transmitting data delay time between the last stop and the next start bit can be programmed 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 de-asserted.

#### 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.15-10 and Table 6.15-11 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.15-10 UART Line Control of Word and Stop Length Setting

| Parity Type                 | SPE<br>(UART_LINE[5]) | EPE<br>(UART_LINE[4]) | PSS<br>(UART_LINE[7]) | PBE<br>(UART_LINE[3]) | Description                                                                                                                                         |
|-----------------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| No Parity                   | x                     | x                     | x                     | 0                     | No parity bit output.                                                                                                                               |
| Parity source from UART_DAT | x                     | x                     | 1                     | 1                     | Parity bit is generated and checked by software.                                                                                                    |
| Odd Parity                  | 0                     | 0                     | 0                     | 1                     | Odd Parity is calculated by adding all the “1’s” in a data stream and adding a parity bit to the total bits, to make the total count an odd number. |
| Even Parity                 | 0                     | 1                     | 0                     | 1                     | Even Parity is calculated by adding all the “1’s” in a data stream and adding a parity bit to the total bits, to make the count an even number.     |
| Forced Mask Parity          | 1                     | 0                     | 0                     | 1                     | Parity bit always logic 1.<br>Parity bit on the serial byte is set to “1” regardless of total number of “1’s” (even or odd counts).                 |
| Forced Space Parity         | 1                     | 1                     | 0                     | 1                     | Parity bit always logic 0.<br>Parity bit on the serial byte is set to “0” regardless of total number of “1’s” (even or odd counts).                 |

Table 6.15-11 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.15-11.



Figure 6.15-11 Auto-Flow Control Block Diagram

Figure 6.15-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.15-12 UART nCTS Auto-Flow Control Enabled

As shown in Figure 6.15-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.15-13 UART nRTS Auto-Flow Control Enabled

As shown in Figure 6.15-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.15-14 UART nRTS Auto-Flow with Software Control

#### 6.15.5.8 IrDA Function Mode

The UART controller also provides Serial IrDA (SIR, Serial Infrared) function (Setting UART\_FUNCSEL [1:0] to '10' to enable the IrDA function). The SIR specification defines a short-range infrared asynchronous serial transmission mode with one start bit, 8 data bits, and 1 stop bit. The maximum data rate is 115.2 kbps. The IrDA SIR block contains an IrDA SIR protocol encoder/decoder. The IrDA SIR protocol is half-duplex only. So, it cannot transmit and receive data at the same time. The IrDA SIR physical layer specifies a minimum 10 ms transfer delay between transmission and reception, and this delay feature must be implemented by software.

In IrDA mode, the BAUDM1 (UART\_BAUD [29]) must be cleared.

**Baud Rate = Clock / (16 \* (BRD +2))**, where BRD (UART\_BAUD[15:0]) is Baud Rate Divider in UART\_BAUD register.

**Note:** The tolerance of baud-rate is  $\pm 5\%$  between IrDA master and IrDA slave.

The IrDA control block diagram is shown in Figure 6.15-15.



Figure 6.15-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.15-16 is IrDA encoder/decoder waveform.



Figure 6.15-16 IrDA TX/RX Timing Diagram

#### 6.15.5.9 LIN Function Mode (Local Interconnection Network)

The UART Controller supports LIN function. Setting FUNCSEL (UART\_FUNCSEL[1:0]) to '01' to select LIN mode operation. The UART Controller supports LIN break/delimiter generation and break/delimiter detection in LIN master mode, and supports header detection and automatic resynchronization in LIN Slave mode.

#### Structure of LIN Frame

According to the LIN protocol, all information transmitted is packed as frames; a frame consists of a header (provided by the master task) and a response (provided by a slave task). The header (provided by the master task) consists of a break field and a sync field followed by a frame identifier (frame ID). The frame identifier uniquely defines the purpose of the frame. The slave task is appointed for providing the response associated with the frame ID. The response consists of a data field and a checksum field. Figure 6.15-17 is the structure of LIN Frame.



Figure 6.15-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.15-18.



Figure 6.15-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[1:0]) to '01' to select LIN function mode operation.

A complete header consists of a break field and sync field followed by a frame identifier (frame ID). The UART controller can be selected header sending by three header selected modes. The header selected mode can be "break field" or "break field and sync field" or "break field, sync field and frame ID field" by setting HSEL (UART\_LINCTL[23:22]). If the selected header is "break field", software must handle the following sequence to send a complete header to bus by filling sync data (0x55) and frame ID data to the UART\_DAT register. If the selected header is "break field and sync field", software must handle the sequence to send a complete header to bus by filling the frame ID data to UART\_DAT register, and if the selected header is "break field, sync field and frame ID 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                                                                        |
| 2    | Generated by Hardware | Generated by Hardware | Generated by Hardware<br>(But Software needs to fill ID to PID (UART_LINCTL[31:24]) first) |

Table 6.15-12 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 P0 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 0x55 into UART\_DAT register.
6. Wait until the RDAIF (UART\_INTSTS[0]) is set to “1” by hardware and then read back the UART\_DAT register.
7. Request header frame ID transmission by writing the protected identifier value to UART\_DAT register.
8. Wait until the RDAIF (UART\_INTSTS[0]) is set to “1” by hardware and then read back the UART\_DAT register.

#### LIN Break and Delimiter Detection

When software enables the break detection function by setting BRKDETEN (UART\_LINCTL[10]), the break detection circuit is activated. The break detection circuit is totally independent from the UART receiver.

When the break detection function is enabled, the circuit looks at the input UART\_RX pin for a start signal. If UART LIN controller detects consecutive dominant is greater than 11 bits dominant followed by a recessive bit (delimiter), the BRKDETF (UART\_LINSTS[8]) flag is set at the end of break field. If the LINIEN (UART\_INTEN[8]) bit is set to 1, an interrupt LININT (UART\_INTSTS[15]) will be generated. The behavior of the break detection and break flag are shown in Figure 6.15-19.



Figure 6.15-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.



Figure 6.15-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[1:0]) to '01'.
4. Enable LIN slave mode by setting the SLVEN (UART\_LINCTL[0]) to 1.

### LIN Header Reception

According to the LIN protocol, a slave node must wait for a valid header which comes from the master node. Next the slave task will take one of following actions (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 SLVIDPEF (UART\_LINSTS[2]) flag is set to ‘1’. If the LINIEN(UART\_INTEN[8]) is set to 1, an interrupt will be generated and SLVHDETF (UART\_LINSTS[0]) is set to ‘1’. User can also put LIN in mute mode by setting MUTE (UART\_LINCTL[4]) to ‘1’. This mode allows detection of headers only (break + sync + frame ID) and prevents the reception of any other characters. In order to avoid bit rate tolerance, the controller supports automatic resynchronization function to avoid clock deviation error, user can enable this feature by setting SLVAREN (UART\_LINCTL[2]).

#### **LIN Response Transmission**

The LIN slave node can transmit response and receive response. When slave node is the publisher of the response, the slave node sends response by filling data to the UART\_DAT register. If the slave node is the subscriber of the response, the slave node receives data from LIN bus.

#### **LIN Header Time-out Error**

The LIN slave controller contains a header time-out counter. If the entire header is not received within the maximum time limit of 57 bit times, the header error flag SLVHEF (UART\_LINSTS [1]) will be set. The time-out counter is enabled at each break detect edge and stopped in the following conditions.

- A LIN frame ID field has been received.
- The header error flag asserts.
- Writing 1 to the SLVSYNCF (UART\_LINSTS[3]) to re-search a new frame header.

#### **Mute Mode and LIN Exit from Mute Mode Condition**

In Mute mode, a LIN slave node will not receive any data until specified condition occurred. It allows header detection only and prevents the reception of any other characters. User can enable Mute mode by setting the MUTE (UART\_LINCTL[4]) and exiting from Mute mode condition can be selected by HSEL (UART\_LINCTL[23:22]).

**Note:** It is recommended to set LIN slave node to Mute mode after checksum transmission.

The LIN slave controller exiting from Mute mode is described as follows: If HSEL (UART\_LINCTL[23:22]) is set to “break field”, when LIN slave controller detects a valid LIN break + delimiter, the controller will enable the receiver (exit from Mute mode) and subsequent data (sync data, frame ID data, response data) are received in RX FIFO.

If HSEL (UART\_LINCTL[23:22]) is set to “break field and sync field”, when the LIN slave controller detects a valid LIN break + delimiter followed by a valid sync field without frame error, the controller will enable the receiver (exit from mute mode) and subsequent data(ID data, response data) are received in RX FIFO. If HSEL (UART\_LINCTL[23:22]) is set to “break field, sync field and ID field”, when the LIN slave controller detects a valid LIN break + delimiter and valid sync field without frame error followed by ID data without frame error and received ID data matched PID (UART\_LINCTL[31:24]) value. The controller will enable the receiver (exit from mute mode) and subsequent data (response data) are received in RX FIFO.

#### **Slave Mode Non-automatic Resynchronization (NAR)**

User can disable the automatic resynchronization function to fix the communication baud rate. When operating in Non-Automatic Resynchronization mode, software needs some initial process, and the initialization process flow of Non-Automatic Resynchronization mode is shown as follows:

1. Select the desired baud rate by setting the UART\_BAUD register.
2. Select LIN function mode by setting FUNCSEL (UART\_FUNCSEL[1:0]) to '01'.
3. Disable automatic resynchronization function by setting SLVAREN (UART\_LINCTL[2]) is set to 0.
4. Enable LIN slave mode by setting the SLVEN (UART\_LINCTL[0]) is set to 1.

#### Slave Mode with Automatic Resynchronization (AR)

In Automatic Resynchronization (AR) mode, the controller will adjust the baud rate generator after each sync field reception. The initialization process flow of Automatic Resynchronization mode is shown as follows:

1. Select the desired baud rate by setting the UART\_BAUD register.
2. Select LIN function mode by setting UART\_FUNCSEL (UART\_FUNCSEL[1:0]) to '01'.
3. Enable automatic resynchronization function by setting SLVAREN (UART\_LINCTL[2]) to '1'.
4. Enable LIN slave mode by setting the SLVEN (UART\_LINCTL[0]) is set to '1'.

When the automatic resynchronization function is enabled, after each LIN break field, the time duration between five falling edges is sampled on peripheral clock and the result of this measurement is stored in an internal 13-bit register and the UART\_BAUD register value will be automatically updated at the end of the fifth falling edge. If the measure timer (13-bit) overflows before five falling edges, then the header error flag SLVHEF (UART\_LINSTS [1]) will be set.



Figure 6.15-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.15-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 re-search 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.15-22 UART\_BAUD Update Sequence in AR mode if SLVDUEN is 1



Figure 6.15-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 re-search a new frame header by writing 1 to SLVSYNCF (UART\_LINSTS[3]) to re-search a new frame header.

The LIN header error flag SLVHEF (UART\_LINSTS[1]) is set if one of the following conditions occurs:

- Break Delimiter is too short (less than 0.5-bit time).
- Frame error in sync field or Identifier field.
- The sync field data is not 0x55 (Non-Automatic Resynchronization mode).
- The sync field deviation error (With Automatic Resynchronization mode).
- The sync field measure time-out (With Automatic Resynchronization mode).
- LIN header reception time-out.

#### 6.15.5.10 RS-485 Function Mode

Another alternate function of UART controller is RS-485 function (user must set UART\_FUNCSEL [1:0] to '11' to enable RS-485 function), and direction control provided by nRTS pin from an asynchronous serial port. The RS-485 transceiver control is implemented by using the nRTS control signal to enable the RS-485 driver. Many characteristics of the RX and TX are same as UART in RS-485 mode.

The UART controller can be configured as an RS-485 addressable slave and the RS-485 master transmitter will identify an address character by setting the parity (9-th bit) to 1. For data characters, the parity is set to 0. Software can use UART\_LINE register to control the 9-th bit (When the PBE, EPE and SPE are set, the 9-th bit is transmitted 0 and when PBE and SPE are set and EPE is cleared, the 9-th bit is transmitted 1).

The controller supports three operation modes: RS-485 Normal Multidrop Operation Mode (NMM), RS-485 Auto Address Detection Operation Mode (AAD) and RS-485 Auto Direction Control Operation Mode (AUD). Software can choose any operation mode by programming the UART\_ALTCTL register, and drive the transfer delay time between the last stop bit leaving the TX FIFO and the de-assertion of by setting DLY (UART\_TOUT [15:8]) register.

#### RS-485 Normal Multidrop Operation Mode (NMM)

In RS-485 Normal Multidrop Operation Mode (RS485NMM (UART\_ALTCTL[8]) = 1), in first, software must decide the data which before the address byte be detected will be stored in RX FIFO or not. If software wants to ignore any data before address byte detected, the flow is set RXOFF (UART\_FIFO

[8]) then enable RS485NMM (UART\_ALTCTL [8]) and the receiver will ignore any data until an address byte is detected (bit 9 = 1) and the address byte data will be stored in the RX FIFO. If software wants to receive any data before address byte detected, the flow is disables RXOFF (UART\_FIFO [8]) then enable RS485NMM (UART\_ALTCTL [8]) and the receiver will received any data.

If an address byte is detected (bit 9 = 1), it will generate an interrupt to CPU and RXOFF (UART\_FIFO [8]) can decide whether accepting the following data bytes are stored in the RX FIFO. If software disables receiver by setting RXOFF (UART\_FIFO [8]) register, when a next address byte is detected, the controller will clear the RXOFF (UART\_FIFO [8]) bit and the address byte data will be stored in the RX FIFO.

#### RS-485 Auto Address Detection Operation Mode (AAD)

In RS-485 Auto Address Detection Operation Mode (RS485AAD (UART\_ALTCTL[9]) = 1), the receiver will ignore any data until an address byte is detected (bit 9 = 1) and the address byte data matches the ADDRMV (UART\_ALTCTL[31:24]) value. The address byte data will be stored in the RX FIFO. The all received byte data will be accepted and stored in the RX FIFO until an address byte data not match the ADDRMV (UART\_ALTCTL[31:24]) value.

#### RS-485 Auto Direction Function (AUD)

Another option function of RS-485 controllers is RS-485 auto direction control function (RS485AUD (UART\_ALTCTL[10] = 1). The RS-485 transceiver control is implemented by using the nRTS control signal from an asynchronous serial port. The nRTS line is connected to the RS-485 transceiver enable pin such that setting the nRTS line to high (logic 1) enables the RS-485 transceiver. Setting the nRTS line to low (logic 0) puts the transceiver into the tri-state condition to disabled. User can set RTSACTLV in UART\_MODEM register to change the nRTS driving level.

Figure 6.15-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.15-24 RS-485 nRTS Driving Level in Auto Direction Mode

Figure 6.15-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.15-26.



Figure 6.15-25 RS-485 nRTS Driving Level with Software Control

**Programming Sequence Example:**

1. Program FUNCSEL in UART\_FUNCSEL to select RS-485 function.
2. Program the RXOFF (UART\_FIFO[8]) to determine enable or disable the receiver RS-485 receiver.
3. Program the RS485NMM (UART\_ALTCTL[8]) or RS485AAD (UART\_ALTCTL[9]) mode.
4. If the RS485AAD (UART\_ALTCTL[9]) mode is selected, the ADDRMRV (UART\_ALTCTL[31:24]) is programmed for auto address match value.
5. Determine auto direction control by programming RS485AUD (UART\_ALTCTL[10]).



Figure 6.15-26 Structure of RS-485 Frame

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

**Note:** If STOPn (PDMA\_STOP[n]) is set to stop UART RXPDMA task and the UART receive is not finish. UART controller will complete the transfer and stored current receive data in receive buffer. By reading RXEMPTY (UART\_FIFOSTS[14]) to check there is valid data in receive buffer or not.

### 6.15.6 Register Map

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

| Register                                     | Offset        | R/W | Description                            | Reset Value |
|----------------------------------------------|---------------|-----|----------------------------------------|-------------|
| <b>UART Base Address:</b>                    |               |     |                                        |             |
| <b>UARTx_BA = 0x4007_0000 + (0x1000 * x)</b> |               |     |                                        |             |
| <b>x=0,1,2,3,4,5</b>                         |               |     |                                        |             |
| <b>UART_DAT</b><br><b>x=0,1,2,3,4,5</b>      | UARTx_BA+0x00 | R/W | UART Receive/Transmit Buffer Register  | Undefined   |
| <b>UART_INTEN</b><br><b>x=0,1,2,3,4,5</b>    | UARTx_BA+0x04 | R/W | UART Interrupt Enable Register         | 0x0000_0000 |
| <b>UART_FIFO</b><br><b>x=0,1,2,3,4,5</b>     | UARTx_BA+0x08 | R/W | UART FIFO Control Register             | 0x0000_0101 |
| <b>UART_LINE</b><br><b>x=0,1,2,3,4,5</b>     | UARTx_BA+0x0C | R/W | UART Line Control Register             | 0x0000_0000 |
| <b>UART_MODEM</b><br><b>x=0,1,2,3,4,5</b>    | UARTx_BA+0x10 | R/W | UART Modem Control Register            | 0x0000_0200 |
| <b>UART_MODEMSTS</b><br><b>x=0,1,2,3,4,5</b> | UARTx_BA+0x14 | R/W | UART Modem Status Register             | 0x0000_0110 |
| <b>UART_FIFOSTS</b><br><b>x=0,1,2,3,4,5</b>  | UARTx_BA+0x18 | R/W | UART FIFO Status Register              | 0xB040_4000 |
| <b>UART_INTSTS</b><br><b>x=0,1,2,3,4,5</b>   | UARTx_BA+0x1C | R/W | UART Interrupt Status Register         | 0x0040_0002 |
| <b>UART_TOUT</b><br><b>x=0,1,2,3,4,5</b>     | UARTx_BA+0x20 | R/W | UART Time-out Register                 | 0x0000_0000 |
| <b>UART_BAUD</b><br><b>x=0,1,2,3,4,5</b>     | UARTx_BA+0x24 | R/W | UART Baud Rate Divider Register        | 0x0F00_0000 |
| <b>UART_IRDA</b><br><b>x=0,1,2,3,4,5</b>     | UARTx_BA+0x28 | R/W | UART IrDA Control Register             | 0x0000_0040 |
| <b>UART_ALTCTL</b><br><b>x=0,1,2,3,4,5</b>   | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | 0x0000_000C |
| <b>UART_FUNCSEL</b><br><b>x=0,1,2,3,4,5</b>  | UARTx_BA+0x30 | R/W | UART Function Select Register          | 0x0000_0000 |
| <b>UART_LINCTL</b><br><b>x=0,1</b>           | UARTx_BA+0x34 | R/W | UART LIN Control Register              | 0x000C_0000 |
| <b>UART_LINSTS</b><br><b>x=0,1</b>           | UARTx_BA+0x38 | R/W | UART LIN Status Register               | 0x0000_0000 |

|                                             |               |     |                                                  |             |
|---------------------------------------------|---------------|-----|--------------------------------------------------|-------------|
| <b>UART_BRCOMP</b><br><b>x=0,1,2,3,4,5</b>  | UARTx_BA+0x3C | R/W | UART Baud Rate Compensation Register             | 0x0000_0000 |
| <b>UART_WKCTL</b><br><b>x=0,1,2,3,4,5</b>   | UARTx_BA+0x40 | R/W | UART Wake-up Control Register                    | 0x0000_0000 |
| <b>UART_WKSTS</b><br><b>x=0,1,2,3,4,5</b>   | UARTx_BA+0x44 | R/W | UART Wake-up Status Register                     | 0x0000_0000 |
| <b>UART_DWKCOMP</b><br><b>x=0,1,2,3,4,5</b> | UARTx_BA+0x48 | R/W | UART Incoming Data Wake-up Compensation Register | 0x0000_0000 |

### 6.15.7 Register Description

#### UART Receive/Transmit Buffer Register (UART\_DAT)

| Register                  | Offset        | R/W | Description                           | Reset Value |
|---------------------------|---------------|-----|---------------------------------------|-------------|
| UART_DAT<br>x=0,1,2,3,4,5 | UARTx_BA+0x00 | R/W | UART Receive/Transmit Buffer Register | Undefined   |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [8]    | PARITY      | <p><b>Parity Bit Receive/Transmit Buffer</b></p> <p>Write Operation:</p> <p>By writing to this bit, the parity bit will be stored in transmitter FIFO. If PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are set, the UART controller will send out this bit follow the DAT (UART_DAT[7:0]) through the UART_TXD.</p> <p>Read Operation:</p> <p>If PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are enabled, the parity bit can be read by this bit.</p> <p><b>Note:</b> This bit has effect only when PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are set.</p> |
| [7:0]  | DAT         | <p><b>Data Receive/Transmit Buffer</b></p> <p>Write Operation:</p> <p>By writing one byte to this register, the data byte will be stored in transmitter FIFO. The UART controller will send out the data stored in transmitter FIFO top location through the UART_TXD.</p> <p>Read Operation:</p> <p>By reading this register, the UART controller will return an 8-bit data received from receiver FIFO.</p>                                                                                                                                         |

**UART Interrupt Enable Register (UART\_INTEN)**

| Register                    | Offset        | R/W | Description                    |  |  | Reset Value |
|-----------------------------|---------------|-----|--------------------------------|--|--|-------------|
| UART_INTEN<br>x=0,1,2,3,4,5 | UARTx_BA+0x04 | R/W | UART Interrupt Enable Register |  |  | 0x0000_0000 |

|          |          |           |          |          |          |          |        |
|----------|----------|-----------|----------|----------|----------|----------|--------|
| 31       | 30       | 29        | 28       | 27       | 26       | 25       | 24     |
| Reserved |          |           |          |          |          |          |        |
| 23       | 22       | 21        | 20       | 19       | 18       | 17       | 16     |
| Reserved | TXENDIEN | Reserved  |          |          | ABRIEN   | Reserved |        |
| 15       | 14       | 13        | 12       | 11       | 10       | 9        | 8      |
| RXPDMAEN | TXPDMAEN | ATOCTSEN  | ATORTSEN | TOCNTEN  | Reserved |          | LINEN  |
| 7        | 6        | 5         | 4        | 3        | 2        | 1        | 0      |
| Reserved | WKIEN    | BUFERRIEN | RXTOIEN  | MODEMIEN | RLSIEN   | THREIEN  | RDAIEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:23] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [22]    | TXENDIEN    | <p><b>Transmitter Empty Interrupt Enable Bit</b><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.</p>                                                                                                                                                                                                                                                                                 |
| [21:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [18]    | ABRIEN      | <p><b>Auto-baud Rate Interrupt Enable Bit</b><br/> 0 = Auto-baud rate interrupt Disabled.<br/> 1 = Auto-baud rate interrupt Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [17:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [15]    | RXPDMAEN    | <p><b>RX PDMA Enable Bit</b><br/> This bit can enable or disable RX PDMA service.<br/> 0 = RX PDMA Disabled.<br/> 1 = RX PDMA Enabled.</p> <p><b>Note:</b> 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.</p> |
| [14]    | TXPDMAEN    | <p><b>TX PDMA Enable Bit</b><br/> 0 = TX PDMA Disabled.<br/> 1 = TX PDMA Enabled.</p> <p><b>Note:</b> 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</p>                                                                                                                                                                                                                                                                                                                                 |

|        |           |                                                                                                                                                                                                                                                                                                                                        |
|--------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |           | Parity Error Flag PEF(UART_FIFOSTS[4]), UART PDMA transmit 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 transmit request operation continue.                                                           |
| [13]   | ATOCTSEN  | <p><b>nCTS Auto-flow Control Enable Bit</b><br/>           0 = nCTS auto-flow control Disabled.<br/>           1 = nCTS auto-flow control Enabled.</p> <p><b>Note:</b> When nCTS auto-flow is enabled, the UART will send data to external device if nCTS input assert (UART will not send data to device until nCTS is asserted).</p> |
| [12]   | ATORTSEN  | <p><b>nRTS Auto-flow Control Enable Bit</b><br/>           0 = nRTS auto-flow control Disabled.<br/>           1 = nRTS auto-flow control Enabled.</p> <p><b>Note:</b> When nRTS auto-flow is enabled, if the number of bytes in the RX FIFO equals the RTSTRGLV (UART_FIFO[19:16]), the UART will de-assert nRTS signal.</p>          |
| [11]   | TOCNTEN   | <p><b>Receive Buffer Time-out Counter Enable Bit</b><br/>           0 = Receive Buffer Time-out counter Disabled.<br/>           1 = Receive Buffer Time-out counter Enabled.</p>                                                                                                                                                      |
| [10:9] | Reserved  | Reserved.                                                                                                                                                                                                                                                                                                                              |
| [8]    | LINIEN    | <p><b>LIN Bus Interrupt Enable Bit</b><br/>           0 = LIN bus interrupt Disabled.<br/>           1 = LIN bus interrupt Enabled.</p> <p><b>Note:</b> This bit is used for LIN function mode.</p>                                                                                                                                    |
| [7]    | Reserved  | Reserved.                                                                                                                                                                                                                                                                                                                              |
| [6]    | WKIEN     | <p><b>Wake-up Interrupt Enable Bit</b><br/>           0 = Wake-up Interrupt Disabled.<br/>           1 = Wake-up Interrupt Enabled.</p>                                                                                                                                                                                                |
| [5]    | BUFERRIEN | <p><b>Buffer Error Interrupt Enable Bit</b><br/>           0 = Buffer error interrupt Disabled.<br/>           1 = Buffer error interrupt Enabled.</p>                                                                                                                                                                                 |
| [4]    | RXTOIEN   | <p><b>RX Time-out Interrupt Enable Bit</b><br/>           0 = RX time-out interrupt Disabled.<br/>           1 = RX time-out interrupt Enabled.</p>                                                                                                                                                                                    |
| [3]    | MODEMIEN  | <p><b>Modem Status Interrupt Enable Bit</b><br/>           0 = Modem status interrupt Disabled.<br/>           1 = Modem status interrupt Enabled.</p>                                                                                                                                                                                 |
| [2]    | RLSIEN    | <p><b>Receive Line Status Interrupt Enable Bit</b><br/>           0 = Receive Line Status interrupt Disabled.<br/>           1 = Receive Line Status interrupt Enabled.</p>                                                                                                                                                            |
| [1]    | THREIEN   | <p><b>Transmit Holding Register Empty Interrupt Enable Bit</b><br/>           0 = Transmit holding register empty interrupt Disabled.<br/>           1 = Transmit holding register empty interrupt Enabled.</p>                                                                                                                        |
| [0]    | RDAIEN    | <p><b>Receive Data Available Interrupt Enable Bit</b><br/>           0 = Receive data available interrupt Disabled.<br/>           1 = Receive data available interrupt Enabled.</p>                                                                                                                                                   |

UART FIFO Control Register (UART\_FIFO)

| Register                   | Offset        | R/W | Description                |  |  |  | Reset Value |
|----------------------------|---------------|-----|----------------------------|--|--|--|-------------|
| UART_FIFO<br>x=0,1,2,3,4,5 | UARTx_BA+0x08 | R/W | UART FIFO Control Register |  |  |  | 0x0000_0101 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [19:16] | RTSTRGLV    | <p><b>nRTS Trigger Level for Auto-flow Control</b><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.</p> <p><b>Note:</b> This field is used for auto nRTS flow control.</p>                                                                                                                                                                |
| [15:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [8]     | RXOFF       | <p><b>Receiver Disable Bit</b><br/>           The receiver is disabled or not (set 1 to disable receiver).<br/>           0 = Receiver Enabled.<br/>           1 = Receiver Disabled.</p> <p><b>Note:</b> This bit is used for RS-485 Normal Multi-drop mode. It should be programmed before RS485NMM (UART_ALTCTL [8]) is programmed.</p>                                                                                                                                                                                                     |
| [7:4]   | RFITL       | <p><b>RX FIFO Interrupt Trigger Level</b><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).</p> <p>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.</p> |
| [3]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [2]     | TXRST       | <b>TX Field Software Reset</b><br>When TXRST (UART_FIFO[2]) is set, all the byte in the transmit FIFO and TX internal                                                                                                                                                                                                                                                                                                                                                                                                                          |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | state machine are cleared.<br>0 = No effect.<br>1 = Reset the TX internal state machine and pointers.<br><b>Note1:</b> This bit will automatically clear at least 3 UART peripheral clock cycles.<br><b>Note2:</b> Before setting this bit, it should wait for the TXEMPTYF (UART_FIFOSTS[28]) be set.                                                                                                                     |
| [1] | <b>RXRST</b>    | <b>RX Field Software Reset</b><br>When RXRST (UART_FIFO[1]) is set, all the byte in the receiver FIFO and RX internal state machine are cleared.<br>0 = No effect.<br>1 = Reset the RX internal state machine and pointers.<br><b>Note1:</b> This bit will automatically clear at least 3 UART peripheral clock cycles.<br><b>Note2:</b> Before setting this bit, it should wait for the RXIDLE (UART_FIFOSTS[29]) be set. |
| [0] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                  |

**UART Line Control Register (UART\_LINE)**

| Register                   | Offset        | R/W | Description                |  |  |  | Reset Value |
|----------------------------|---------------|-----|----------------------------|--|--|--|-------------|
| UART_LINE<br>x=0,1,2,3,4,5 | UARTx_BA+0x0C | R/W | UART Line Control Register |  |  |  | 0x0000_0000 |

|          |     |     |     |     |     |        |        |
|----------|-----|-----|-----|-----|-----|--------|--------|
| 31       | 30  | 29  | 28  | 27  | 26  | 25     | 24     |
| Reserved |     |     |     |     |     |        |        |
| 23       | 22  | 21  | 20  | 19  | 18  | 17     | 16     |
| Reserved |     |     |     |     |     |        |        |
| 15       | 14  | 13  | 12  | 11  | 10  | 9      | 8      |
| Reserved |     |     |     |     |     | RXDINV | TXDINV |
| 7        | 6   | 5   | 4   | 3   | 2   | 1      | 0      |
| PSS      | BCB | SPE | EPE | PBE | NSB | WLS    |        |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [9]     | RXDINV      | <p><b>RX Data Inverted</b><br/>           0 = Received data signal inverted Disabled.<br/>           1 = Received data signal inverted Enabled.</p> <p><b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.</p> <p><b>Note2:</b> This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select UART, LIN or RS485 function.</p>                                                                                                                                                                         |
| [8]     | TXDINV      | <p><b>TX Data Inverted</b><br/>           0 = Transmitted data signal inverted Disabled.<br/>           1 = Transmitted data signal inverted Enabled.</p> <p><b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.</p> <p><b>Note2:</b> This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select UART, LIN or RS485 function.</p>                                                                                                                                                                   |
| [7]     | PSS         | <p><b>Parity Bit Source Selection</b><br/>           The parity bit can be selected to be generated and checked automatically or by software.<br/>           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.</p> <p><b>Note1:</b> This bit has effect only when PBE (UART_LINE[3]) is set.</p> <p><b>Note2:</b> If PSS is 0, the parity bit is transmitted and checked automatically. If PSS is 1, the transmitted parity bit value can be determined by writing PARITY (UART_DAT[8]) and the parity bit can be read by reading PARITY (UART_DAT[8]).</p> |
| [6]     | BCB         | <p><b>Break Control Bit</b><br/>           0 = Break Control Disabled.<br/>           1 = Break Control Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|       |            |                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            | <b>Note:</b> 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]   | <b>SPE</b> | <p><b>Stick Parity Enable Bit</b><br/>           0 = Stick parity Disabled.<br/>           1 = Stick parity Enabled.</p> <p><b>Note:</b> 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.</p> |
| [4]   | <b>EPE</b> | <p><b>Even Parity Enable Bit</b><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.</p> <p><b>Note:</b> This bit has effect only when PBE (UART_LINE[3]) is set.</p>                                                                               |
| [3]   | <b>PBE</b> | <p><b>Parity Bit Enable Bit</b><br/>           0 = Parity bit generated Disabled.<br/>           1 = Parity bit generated Enabled.</p> <p><b>Note:</b> Parity bit is generated on each outgoing character and is checked on each incoming data.</p>                                                                                                                      |
| [2]   | <b>NSB</b> | <p><b>Number of “STOP Bit”</b><br/>           0 = One “STOP bit” is generated in the transmitted data.<br/>           1 = When select 5-bit word length, 1.5 “STOP bit” is generated in the transmitted data.<br/>           When select 6-, 7- and 8-bit word length, 2 “STOP bit” is generated in the transmitted data.</p>                                            |
| [1:0] | <b>WLS</b> | <p><b>Word Length Selection</b><br/>           This field sets UART word length.<br/>           00 = 5 bits.<br/>           01 = 6 bits.<br/>           10 = 7 bits.<br/>           11 = 8 bits.</p>                                                                                                                                                                     |

**UART Modem Control Register (UART\_MODEM)**

| Register                    | Offset        | R/W | Description                 | Reset Value |
|-----------------------------|---------------|-----|-----------------------------|-------------|
| UART_MODEM<br>x=0,1,2,3,4,5 | UARTx_BA+0x10 | R/W | UART Modem Control Register | 0x0000_0200 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [13]    | <b>RTSSTS</b>   | <p><b>nRTS Pin Status (Read Only)</b><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.</p>                                                                                                                                                                                                                                                                                                                                                                                                   |
| [12:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [9]     | <b>RTSACTLV</b> | <p><b>nRTS Pin Active Level</b><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)</p> <p><b>Note1:</b> Refer to Figure 6.15-13 and Figure 6.15-14 for UART function mode.<br/> <b>Note2:</b> Refer to Figure 6.15-24 and Figure 6.15-25 for RS-485 function mode.<br/> <b>Note3:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.</p> |
| [8:2]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [1]     | <b>RTS</b>      | <p><b>nRTS (Request-to-send) Signal Control</b><br/> This bit is direct control internal nRTS signal active or not, and then drive the nRTS pin output with RTSACTLV bit configuration.<br/> 0 = nRTS signal is active.<br/> 1 = nRTS signal is inactive.</p> <p><b>Note1:</b> The nRTS signal control bit is not effective when nRTS auto-flow control is enabled in UART function mode.<br/> <b>Note2:</b> The nRTS signal control bit is not effective when RS-485 auto direction mode (AUD) is enabled in RS-485 function mode.</p>                                                                                               |
| [0]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**UART Modem Status Register (UART\_MODEMSTS)**

| Register                       | Offset        | R/W | Description                |  |  |  | Reset Value |
|--------------------------------|---------------|-----|----------------------------|--|--|--|-------------|
| UART_MODEMSTS<br>x=0,1,2,3,4,5 | UARTx_BA+0x14 | R/W | UART Modem Status Register |  |  |  | 0x0000_0110 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [8]    | CTSACTLV    | <p><b>nCTS Pin Active Level</b><br/>           This bit defines the active level state of nCTS pin input.<br/>           0 = nCTS pin input is high level active.<br/>           1 = nCTS pin input is low level active. (Default)</p> <p><b>Note:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.</p> |
| [7:5]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [4]    | CTSSTS      | <p><b>nCTS Pin Status (Read Only)</b><br/>           This bit mirror from nCTS pin input of voltage logic status.<br/>           0 = nCTS pin input is low level voltage logic state.<br/>           1 = nCTS pin input is high level voltage logic state.</p> <p><b>Note:</b> This bit echoes when UART controller peripheral clock is enabled, and nCTS multi-function port is selected.</p>                                                                                    |
| [3:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]    | CTSDETF     | <p><b>Detect nCTS State Change Flag</b><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.</p> <p><b>Note:</b> This bit can be cleared by writing "1" to it.</p>                                                                                                    |

**UART FIFO Status Register (UART\_FIFOSTS)**

| Register                      | Offset        | R/W | Description               |  |  |  | Reset Value |
|-------------------------------|---------------|-----|---------------------------|--|--|--|-------------|
| UART_FIFOSTS<br>x=0,1,2,3,4,5 | UARTx_BA+0x18 | R/W | UART FIFO Status Register |  |  |  | 0xB040_4000 |

| 31       | 30       | 29     | 28       | 27       | 26       | 25     | 24     |
|----------|----------|--------|----------|----------|----------|--------|--------|
| TXRXACT  | Reserved | RXIDLE | TXEMPTYF | Reserved |          | TXOVIF |        |
| 23       | 22       | 21     | 20       | 19       | 18       | 17     | 16     |
| TXFULL   | TXEMPTY  | TXPTR  |          |          |          |        |        |
| 15       | 14       | 13     | 12       | 11       | 10       | 9      | 8      |
| RXFULL   | RXEMPTY  | RXPTR  |          |          |          |        |        |
| 7        | 6        | 5      | 4        | 3        | 2        | 1      | 0      |
| Reserved | BIF      | FEF    | PEF      | ADDRDETF | ABRDTOIF | ABRDIF | RXOVIF |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>TXRXACT</b><br><b>TX and RX Active Status (Read Only)</b><br>This bit indicates TX and RX are active or inactive.<br>0 = TX and RX are inactive.<br>1 = TX and RX are active. (Default)<br><b>Note:</b> When TXRXDIS (UART_FUNCSEL[3]) is set and both TX and RX are in idle state, this bit is cleared. The UART controller can not transmit or receive data at this moment. Otherwise this bit is set.                                                                              |
| [30]    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [29]    | <b>RXIDLE</b><br><b>RX Idle Status (Read Only)</b><br>This bit is set by hardware when RX is idle.<br>0 = RX is busy.<br>1 = RX is idle. (Default)                                                                                                                                                                                                                                                                                                                                       |
| [28]    | <b>TXEMPTYF</b><br><b>Transmitter Empty Flag (Read Only)</b><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><b>Note:</b> This bit is cleared automatically when TX FIFO is not empty or the last byte transmission has not completed. |
| [27:25] | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [24]    | <b>TXOVIF</b><br><b>TX Overflow Error Interrupt Flag</b><br>If TX FIFO (UART_DAT) is full, an additional write to UART_DAT will cause this bit to logic 1.<br>0 = TX FIFO is not overflow.<br>1 = TX FIFO is overflow.<br><b>Note:</b> This bit can be cleared by writing "1" to it.                                                                                                                                                                                                     |
| [23]    | <b>TXFULL</b><br><b>Transmitter FIFO Full (Read Only)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | This bit indicates TX FIFO full or not.<br>0 = TX FIFO is not full.<br>1 = TX FIFO is full.<br><b>Note:</b> This bit is set when the number of usage in TX FIFO Buffer is equal to 16, otherwise it is cleared by hardware.                                                                                                                                                                                                                                                                                                  |
| [22]    | <b>TXEMPTY</b>  | <b>Transmitter FIFO Empty (Read Only)</b><br>This bit indicates TX FIFO empty or not.<br>0 = TX FIFO is not empty.<br>1 = TX FIFO is empty.<br><b>Note:</b> When the last byte of TX FIFO has been transferred to Transmitter Shift Register, hardware sets this bit high. It will be cleared when writing data into UART_DAT (TX FIFO not empty).                                                                                                                                                                           |
| [21:16] | <b>TXPTR</b>    | <b>TX FIFO Pointer (Read Only)</b><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]    | <b>RXFULL</b>   | <b>Receiver FIFO Full (Read Only)</b><br>This bit initiates RX FIFO full or not.<br>0 = RX FIFO is not full.<br>1 = RX FIFO is full.<br><b>Note:</b> This bit is set when the number of usage in RX FIFO Buffer is equal to 16, otherwise it is cleared by hardware.                                                                                                                                                                                                                                                         |
| [14]    | <b>RXEMPTY</b>  | <b>Receiver FIFO Empty (Read Only)</b><br>This bit initiate RX FIFO empty or not.<br>0 = RX FIFO is not empty.<br>1 = RX FIFO is empty.<br><b>Note:</b> When the last byte of RX FIFO has been read by CPU, hardware sets this bit high. It will be cleared when UART receives any new data.                                                                                                                                                                                                                                 |
| [13:8]  | <b>RXPTR</b>    | <b>RX FIFO Pointer (Read Only)</b><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]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [6]     | <b>BIF</b>      | <b>Break Interrupt Flag</b><br>This bit is set to logic 1 whenever the received data input (RX) is held in the “spacing state” (logic 0) for longer than a full word transmission time (that is, the total time of “start bit” + data bits + parity + stop bits).<br>0 = No Break interrupt is generated.<br>1 = Break interrupt is generated.<br><b>Note:</b> This bit can be cleared by writing “1” to it.                                                                                                                 |
| [5]     | <b>FEF</b>      | <b>Framing Error Flag</b><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.                                                                                                                                                                                                                                                                     |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | 1 = Framing error is generated.<br><b>Note:</b> This bit can be cleared by writing "1" to it.                                                                                                                                                                                                                                                                                              |
| [4] | <b>PEF</b>      | <b>Parity Error Flag</b><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><b>Note:</b> This bit can be cleared by writing "1" to it.                                                                                                                            |
| [3] | <b>ADDRDETF</b> | <b>RS-485 Address Byte Detect Flag</b><br>0 = Receiver detects a data that is not an address bit (bit 9 ='0').<br>1 = Receiver detects a data that is an address bit (bit 9 ='1').<br><b>Note1:</b> This field is used for RS-485 function mode and ADDRDEN (UART_ALTCTL[15]) is set to 1 to enable Address detection mode.<br><b>Note2:</b> This bit can be cleared by writing "1" to it. |
| [2] | <b>ABRDTOIF</b> | <b>Auto-baud Rate Detect Time-out Interrupt Flag</b><br>This bit is set to logic "1" in Auto-baud Rate Detect mode when the baud rate counter is overflow.<br>0 = Auto-baud rate counter is underflow.<br>1 = Auto-baud rate counter is overflow.<br><b>Note:</b> This bit can be cleared by writing "1" to it.                                                                            |
| [1] | <b>ABRDIF</b>   | <b>Auto-baud Rate Detect Interrupt Flag</b><br>This bit is set to logic "1" when auto-baud rate detect function is finished.<br>0 = Auto-baud rate detect function is not finished.<br>1 = Auto-baud rate detect function is finished.<br><b>Note:</b> This bit can be cleared by writing "1" to it.                                                                                       |
| [0] | <b>RXOVIF</b>   | <b>RX Overflow Error Interrupt Flag</b><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><b>Note:</b> 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>x=0,1,2,3,4,5 | UARTx_BA+0x1C | R/W | UART Interrupt Status Register |  |  |  | 0x0040_0002 |

| 31       | 30       | 29        | 28      | 27       | 26       | 25       | 24     |
|----------|----------|-----------|---------|----------|----------|----------|--------|
| ABRINT   | TXENDINT | HWBUFEINT | HWTOINT | HWMODINT | HWRLSINT | Reserved |        |
| 23       | 22       | 21        | 20      | 19       | 18       | 17       | 16     |
| Reserved | TXENDIF  | HWBUFEIF  | HWTOIF  | HWMODIF  | HWRLSIF  | Reserved |        |
| 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] | <b>ABRINT</b><br><b>Auto-baud Rate Interrupt Indicator (Read Only)</b><br>This bit is set if ABRIEN (UART_INTEN[18]) and ABRIF (UART_ALTCTL[17]) are both set to 1.<br>0 = No Auto-baud Rate interrupt is generated.<br>1 = The Auto-baud Rate interrupt is generated.                                   |
| [30] | <b>TXENDINT</b><br><b>Transmitter Empty Interrupt Indicator (Read Only)</b><br>This bit is set if TXENDIEN (UART_INTEN[22]) and TXENDIF(UART_INTSTS[22]) are both set to 1.<br>0 = No Transmitter Empty interrupt is generated.<br>1 = Transmitter Empty interrupt is generated.                         |
| [29] | <b>HWBUFEINT</b><br><b>PDMA Mode Buffer Error Interrupt Indicator (Read Only)</b><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] | <b>HWTOINT</b><br><b>PDMA Mode RX Time-out Interrupt Indicator (Read Only)</b><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 = RX time-out interrupt is generated in PDMA mode.           |
| [27] | <b>HWMODINT</b><br><b>PDMA Mode MODEM Status Interrupt Indicator (Read Only)</b><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] | <b>HWRLSINT</b><br><b>PDMA Mode Receive Line Status Interrupt Indicator (Read Only)</b><br>This bit is set if RLSIEN (UART_INTEN[2]) and HWRLSIF(UART_INTSTS[18]) are both set to 1.                                                                                                                     |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 0 = No RLS interrupt is generated in PDMA mode.<br>1 = RLS interrupt is generated in PDMA mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [25:23] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [22]    | <b>TXENDIF</b>  | <p><b>Transmitter Empty Interrupt Flag</b></p> <p>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.</p> <p>0 = No transmitter empty interrupt flag is generated.<br/>1 = Transmitter empty interrupt flag is generated.</p> <p><b>Note:</b> This bit is cleared automatically when TX FIFO is not empty or the last byte transmission has not completed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [21]    | <b>HWBUFEIF</b> | <p><b>PDMA Mode Buffer Error Interrupt Flag (Read Only)</b></p> <p>This bit is set when the TX or RX FIFO overflows (TXOVIF (UART_FIFOSTS [24]) or RXOVIF (UART_FIFOSTS[0]) is set). When BUERRIF (UART_INTSTS[5]) is set, the transfer maybe is not correct. If BUERRIEN (UART_INTEN [5]) is enabled, the buffer error interrupt will be generated.</p> <p>0 = No buffer error interrupt flag is generated in PDMA mode.<br/>1 = Buffer error interrupt flag is generated in PDMA mode.</p> <p><b>Note:</b> This bit is cleared when both TXOVIF (UART_FIFOSTS[24])) and RXOVIF (UART_FIFOSTS[0]) are cleared.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |
| [20]    | <b>HWTOIF</b>   | <p><b>PDMA Mode RX Time-out Interrupt Flag (Read Only)</b></p> <p>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 .</p> <p>0 = No RX time-out interrupt flag is generated in PDMA mode.<br/>1 = RX time-out interrupt flag is generated in PDMA mode.</p> <p><b>Note:</b> This bit is read only and user can read UART_DAT (RX is in active) to clear it.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [19]    | <b>HWMODIF</b>  | <p><b>PDMA Mode MODEM Interrupt Flag (Read Only)</b></p> <p>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.</p> <p>0 = No Modem interrupt flag is generated in PDMA mode.<br/>1 = Modem interrupt flag is generated in PDMA mode.</p> <p><b>Note:</b> 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]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [18]    | <b>HWRLSIF</b>  | <p><b>PDMA Mode Receive Line Status Flag (Read Only)</b></p> <p>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.</p> <p>0 = No RLS interrupt flag is generated in PDMA mode.<br/>1 = RLS interrupt flag is generated in PDMA mode.</p> <p><b>Note1:</b> In RS-485 function mode, this field include "receiver detect any address byte received address byte character (bit9 = '1') bit".</p> <p><b>Note2:</b> In UART function mode, this bit is read only and reset to 0 when all bits of BIF(UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]) are cleared.</p> <p><b>Note3:</b> In RS-485 function mode, this bit is read only and reset to 0 when all bits of BIF(UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]), PEF(UART_FIFOSTS[4]) and ADDRDETF (UART_FIFOSTS[3]) are cleared.</p> |
| [17:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [15]    | <b>LININT</b>   | <b>LIN Bus Interrupt Indicator (Read Only)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|      |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |           | This bit is set if LINIEN (UART_INTEN[8]) and LINIF(UART_INTSTS[7]) are both set to 1.<br>0 = No LIN Bus interrupt is generated.<br>1 = The LIN Bus interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [14] | WKINT     | <b>UART Wake-up Interrupt Indicator (Read Only)</b><br>This bit is set if WKIEN (UART_INTEN[6]) and WKIF (UART_INTSTS[6]) are both set to 1.<br>0 = No UART wake-up interrupt is generated.<br>1 = UART wake-up interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [13] | BUFERRINT | <b>Buffer Error Interrupt Indicator (Read Only)</b><br>This bit is set if BUFERRIEN(UART_INTEN[5]) and BUFERRIF(UART_INTSTS[5]) are both set to 1.<br>0 = No buffer error interrupt is generated.<br>1 = Buffer error interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [12] | RXTOINT   | <b>RX Time-out Interrupt Indicator (Read Only)</b><br>This bit is set if RXTOIEN (UART_INTEN[4]) and RXTOIF(UART_INTSTS[4]) are both set to 1.<br>0 = No RX time-out interrupt is generated.<br>1 = RX time-out interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [11] | MODEMINT  | <b>MODEM Status Interrupt Indicator (Read Only)</b><br>This bit is set if MODEMIEN(UART_INTEN[3]) and MODEMIF(UART_INTSTS[3]) are both set to 1<br>0 = No Modem interrupt is generated.<br>1 = Modem interrupt is generated..                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [10] | RLSINT    | <b>Receive Line Status Interrupt Indicator (Read Only)</b><br>This bit is set if RLSIEN (UART_INTEN[2]) and RLSIF(UART_INTSTS[2]) are both set to 1.<br>0 = No RLS interrupt is generated.<br>1 = RLS interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [9]  | THREINT   | <b>Transmit Holding Register Empty Interrupt Indicator (Read Only)</b><br>This bit is set if THREIEN (UART_INTEN[1]) and THREIF(UART_INTSTS[1]) are both set to 1.<br>0 = No THRE interrupt is generated.<br>1 = THRE interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [8]  | RDAINT    | <b>Receive Data Available Interrupt Indicator (Read Only)</b><br>This bit is set if RDIAIEN (UART_INTEN[0]) and RDIAIF (UART_INTSTS[0]) are both set to 1.<br>0 = No RDA interrupt is generated.<br>1 = RDA interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [7]  | LINIF     | <b>LIN Bus Interrupt Flag</b><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><b>Note:</b> This bit is cleared when SLVHDETF(UART_LINSTS[0]), BRKDETF(UART_LINSTS[8]), BITEF(UART_LINSTS[9]), SLVIDPEF (UART_LINSTS[2]) and SLVHEF(UART_LINSTS[1]) all are cleared and software writing '1' to |

|     |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          | LINIF(UART_INTSTS[7]).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [6] | WKIF     | <p><b>UART Wake-up Interrupt Flag (Read Only)</b><br/> This bit is set when TOUTWKF (UART_WKSTS[4]), RS485WKF (UART_WKSTS[3]), RFRTWKF (UART_WKSTS[2]), DATWKF (UART_WKSTS[1]) or CTSWKF(UART_WKSTS[0]) is set to 1.<br/> 0 = No UART wake-up interrupt flag is generated.<br/> 1 = UART wake-up interrupt flag is generated.</p> <p><b>Note:</b> This bit is cleared if all of TOUTWKF, RS485WKF, RFRTWKF, DATWKF and CTSWKF are cleared to 0 by writing 1 to the corresponding interrupt flag.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [5] | BUFERRIF | <p><b>Buffer Error Interrupt Flag (Read Only)</b><br/> This bit is set when the TX FIFO or RX FIFO overflows (TXOVIF (UART_FIFOSTS[24]) or RXOVIF (UART_FIFOSTS[0]) is set). When BUFERRIEN (UART_INTEN [5]) is set, the transfer 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.<br/> 1 = Buffer error interrupt flag is generated.</p> <p><b>Note:</b> This bit is cleared if both of RXOVIF(UART_FIFOSTS[0]) and TXOVIF(UART_FIFOSTS[24]) are cleared to 0 by writing 1 to RXOVIF(UART_FIFOSTS[0]) and TXOVIF(UART_FIFOSTS[24]).</p>                                                                                                                                                                                                                                                                                                                                                                          |
| [4] | RXTOIF   | <p><b>RX Time-out Interrupt Flag (Read Only)</b><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.<br/> 1 = RX time-out interrupt flag is generated.</p> <p><b>Note:</b> This bit is read only and user can read UART_DAT (RX is in active) to clear it.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [3] | MODEMIF  | <p><b>MODEM Interrupt Flag (Read Only)</b><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.<br/> 1 = Modem interrupt flag is generated.</p> <p><b>Note:</b> This bit is read only and reset to 0 when bit CTSDETF is cleared by a write 1 on CTSDETF(UART_MODEMSTS[0]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [2] | RLSIF    | <p><b>Receive Line Interrupt Flag (Read Only)</b><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.<br/> 1 = RLS interrupt flag is generated.</p> <p><b>Note1:</b> 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.</p> <p><b>Note2:</b> This bit is read only and reset to 0 when all bits of BIF (UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]) are cleared.</p> <p><b>Note3:</b> In RS-485 function mode, this bit is read only and reset to 0 when all bits of BIF (UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]), PEF(UART_FIFOSTS[4]) and ADDRDETF (UART_FIFOSTS[3]) are cleared</p> |
| [1] | THREIF   | <p><b>Transmit Holding Register Empty Interrupt Flag</b><br/> 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.<br/> 0 = No THRE interrupt flag is generated.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|     |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |              | <p>1 = THRE interrupt flag is generated.</p> <p><b>Note:</b> This bit is read only and it will be cleared when writing data into UART_DAT (TX FIFO not empty).</p>                                                                                                                                                                                                                                                                                                                                          |
| [0] | <b>RDAIF</b> | <p><b>Receive Data Available Interrupt Flag</b></p> <p>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.</p> <p>0 = No RDA interrupt flag is generated.</p> <p>1 = RDA interrupt flag is generated.</p> <p><b>Note:</b> This bit is read only and it will be cleared when the number of unread bytes of RX FIFO drops below the threshold level (RFITL(UART_FIFO[7:4])).</p> |

UART Time-out Register (UART\_TOUT)

| Register                   | Offset        | R/W | Description            | Reset Value |
|----------------------------|---------------|-----|------------------------|-------------|
| UART_TOUT<br>x=0,1,2,3,4,5 | UARTx_BA+0x20 | R/W | UART Time-out Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [15:8]  | DLY         | <b>TX Delay Time Value</b><br>This field is used to programming the transfer delay time between the last stop bit and next start bit. The unit is bit time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [7:0]   | TOIC        | <b>Time-out Interrupt Comparator</b><br>The time-out counter resets and starts counting (the counting clock = baud rate) whenever the RX FIFO receives a new data word if time out counter is enabled by setting TOCNTEN (UART_INTEN[11]). Once the content of time-out counter is equal to that of time-out interrupt comparator (TOIC (UART_TOUT[7:0])), a receiver time-out interrupt (RXTOINT(UART_INTSTS[12])) is generated if RXTOIEN (UART_INTEN [4]) enabled. A new incoming data word or RX FIFO empty will clear RXTOIF (UART_INTSTS[4]). In order to avoid receiver time-out interrupt generation immediately during one character is being received, TOIC value should be set between 40 and 255. So, for example, if TOIC is set with 40, the time-out interrupt is generated after four characters are not received when 1 stop bit and no parity check is set for UART transfer. |

**UART Baud Rate Divider Register (UART\_BAUD)**

| Register                   | Offset        | R/W | Description                     | Reset Value |
|----------------------------|---------------|-----|---------------------------------|-------------|
| UART_BAUD<br>x=0,1,2,3,4,5 | UARTx_BA+0x24 | R/W | UART Baud Rate Divider Register | 0x0F00_0000 |



| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                     |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                           |
| [29]    | <b>BAUDM1</b>   | <b>BAUD Rate Mode Selection Bit 1</b><br>This bit is baud rate mode selection bit 1. UART provides three baud rate calculation modes. This bit combines with BAUDM0 (UART_BAUD[28]) to select baud rate calculation mode. The detail description is shown in Table 6.15-4.<br><b>Note:</b> In IrDA mode must be operated in mode 0. |
| [28]    | <b>BAUDM0</b>   | <b>BAUD Rate Mode Selection Bit 0</b><br>This bit is baud rate mode selection bit 0. UART provides three baud rate calculation modes. This bit combines with BAUDM1 (UART_BAUD[29]) to select baud rate calculation mode. The detail description is shown in Table 6.15-4.                                                          |
| [27:24] | <b>EDIVM1</b>   | <b>Extra Divider for BAUD Rate Mode 1</b><br>This field is used for baud rate calculation in mode 1 and has no effect for baud rate calculation in mode 0 and mode 2. The detail description is shown in Table 6.15-4.                                                                                                              |
| [23:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                           |
| [15:0]  | <b>BRD</b>      | <b>Baud Rate Divider</b><br>The field indicates the baud rate divider. This filed is used in baud rate calculation. The detail description is shown in Table 6.15-4.                                                                                                                                                                |

**UART IrDA Control Register (UART\_IRDA)**

| Register                   | Offset        | R/W | Description                | Reset Value |
|----------------------------|---------------|-----|----------------------------|-------------|
| UART_IRDA<br>x=0,1,2,3,4,5 | UARTx_BA+0x28 | R/W | UART IrDA Control Register | 0x0000_0040 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [6]    | RXINV       | <p><b>IrDA Inverse Receive Input Signal</b><br/>           0 = None inverse receiving input signal.<br/>           1 = Inverse receiving input signal. (Default)</p> <p><b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.</p> <p><b>Note2:</b> This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select IrDA function.</p>         |
| [5]    | TXINV       | <p><b>IrDA Inverse Transmitting Output Signal</b><br/>           0 = None inverse transmitting signal. (Default).<br/>           1 = Inverse transmitting output signal.</p> <p><b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.</p> <p><b>Note2:</b> This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select IrDA function.</p> |
| [4:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [1]    | TXEN        | <p><b>IrDA Receiver/Transmitter Selection Enable Bit</b><br/>           0 = IrDA Transmitter Disabled and Receiver Enabled. (Default)<br/>           1 = IrDA Transmitter Enabled and Receiver Disabled.</p>                                                                                                                                                                                                                                                                                                              |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**UART Alternate Control/Status Register (UART\_ALTCTL)**

| Register                     | Offset        | R/W | Description                            | Reset Value |
|------------------------------|---------------|-----|----------------------------------------|-------------|
| UART_ALTCTL<br>x=0,1,2,3,4,5 | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | 0x0000_000C |

|          |          |          |          |          |          |          |          |
|----------|----------|----------|----------|----------|----------|----------|----------|
| 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
| ADDRMV   |          |          |          |          |          |          |          |
| 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| Reserved |          |          | ABRDBITS |          | 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      | <b>Address Match Value</b><br>This field contains the RS-485 address match values.<br><b>Note:</b> This field is used for RS-485 auto address detection mode.                                                                                                                                                                                                                                                                                                                                             |
| [23:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [20:19] | ABRDBITS    | <b>Auto-baud Rate Detect Bit Length</b><br>00 = 1-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x01.<br>01 = 2-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x02.<br>10 = 4-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x08.<br>11 = 8-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x80.<br><b>Note :</b> The calculation of bit number includes the START bit.                |
| [18]    | ABRDEN      | <b>Auto-baud Rate Detect Enable Bit</b><br>0 = Auto-baud rate detect function Disabled.<br>1 = Auto-baud rate detect function Enabled.<br><b>Note :</b> This bit is cleared automatically after auto-baud detection is finished.                                                                                                                                                                                                                                                                          |
| [17]    | ABRIF       | <b>Auto-baud Rate Interrupt Flag (Read Only)</b><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><b>Note:</b> 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     | <b>RS-485 Address Detection Enable Bit</b><br>This bit is used to enable RS-485 Address Detection mode.<br>0 = Address detection mode Disabled.                                                                                                                                                                                                                                                                                                                                                           |

|         |                 |                                                                                                                                                                                                                                                                      |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 1 = Address detection mode Enabled.<br><b>Note:</b> This bit is used for RS-485 any operation mode.                                                                                                                                                                  |
| [14:11] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                            |
| [10]    | <b>RS485AUD</b> | <b>RS-485 Auto Direction Function (AUD)</b><br>0 = RS-485 Auto Direction Operation function (AUD) Disabled.<br>1 = RS-485 Auto Direction Operation function (AUD) Enabled.<br><b>Note:</b> It can be active with RS-485_AAD or RS-485_NMM operation mode.            |
| [9]     | <b>RS485AAD</b> | <b>RS-485 Auto Address Detection Operation Mode (AAD)</b><br>0 = RS-485 Auto Address Detection Operation mode (AAD) Disabled.<br>1 = RS-485 Auto Address Detection Operation mode (AAD) Enabled.<br><b>Note:</b> It cannot be active with RS-485_NMM operation mode. |
| [8]     | <b>RS485NMM</b> | <b>RS-485 Normal Multi-drop Operation Mode (NMM)</b><br>0 = RS-485 Normal Multi-drop Operation mode (NMM) Disabled.<br>1 = RS-485 Normal Multi-drop Operation mode (NMM) Enabled.<br><b>Note:</b> It cannot be active with RS-485_AAD operation mode.                |
| [7]     | <b>LINTXEN</b>  | <b>LIN TX Break Mode Enable Bit</b><br>0 = LIN TX Break mode Disabled.<br>1 = LIN TX Break mode Enabled.<br><b>Note:</b> When TX break field transfer operation finished, this bit will be cleared automatically.                                                    |
| [6]     | <b>LINRXEN</b>  | <b>LIN RX Enable Bit</b><br>0 = LIN RX mode Disabled.<br>1 = LIN RX mode Enabled.                                                                                                                                                                                    |
| [5:4]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                            |
| [3:0]   | <b>BRKFL</b>    | <b>UART LIN Break Field Length</b><br>This field indicates a 4-bit LIN TX break field count.<br><b>Note1:</b> This break field length is BRKFL + 1.<br><b>Note2:</b> 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>x=0,1,2,3,4,5 | UARTx_BA+0x30 | R/W | UART Function Select Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                       |
| [3]    | TXRXDIS     | <p><b>TX and RX Disable Bit</b><br/> Setting this bit can disable TX and RX.<br/> 0 = TX and RX Enabled.<br/> 1 = TX and RX Disabled.</p> <p><b>Note:</b> The TX and RX will not disable immediately when this bit is set. The TX and RX complete current task before disable TX and RX. When TX and RX disable, the TXRXACT (UART_FIFOSTS[31]) is cleared.</p> |
| [2]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                       |
| [1:0]  | FUNCSEL     | <p><b>Function Select</b><br/> 00 = UART function.<br/> 01 = LIN function.<br/> 10 = IrDA function.<br/> 11 = RS-485 function.</p>                                                                                                                                                                                                                              |

UART LIN Control Register (UART\_LINCTL)

| Register             | Offset        | R/W | Description               | Reset Value |
|----------------------|---------------|-----|---------------------------|-------------|
| UART_LINCTL<br>x=0,1 | 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     |    |    |          |          |          |         |       |
| 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] | <b>PID</b>      | <p><b>LIN PID Bits</b><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 ID0~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.</p> <p><b>Note1:</b> User can fill any 8-bit value to this field and the bit 24 indicates ID0 (LSB first).<br/> <b>Note2:</b> This field can be used for LIN master mode or slave mode.</p> |
| [23:22] | <b>HSEL</b>     | <p><b>LIN Header Select</b><br/> 00 = The LIN header includes “break field”.<br/> 01 = The LIN header includes “break field” and “sync field”.<br/> 10 = The LIN header includes “break field”, “sync field” and “frame ID field”.<br/> 11 = Reserved.</p> <p><b>Note:</b> 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)).</p>                                                                                                                               |
| [21:20] | <b>BSL</b>      | <p><b>LIN Break/Sync Delimiter Length</b><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.</p> <p><b>Note:</b> This bit used for LIN master to sending header field.</p>                                                                                                                                                                                                                      |
| [19:16] | <b>BRKFL</b>    | <p><b>LIN Break Field Length</b><br/> This field indicates a 4-bit LIN TX break field count.</p> <p><b>Note1:</b> 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]).</p> <p><b>Note2:</b> This break field length is BRKFL + 1.</p> <p><b>Note3:</b> According to LIN spec, the reset value is 12 (break field length = 13).</p>                                                                                                                                                        |
| [15:13] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [12]  | <b>BITERREN</b> | <b>Bit Error Detect Enable Bit</b><br>0 = Bit error detection function Disabled.<br>1 = Bit error detection function Enabled.<br><b>Note:</b> In LIN function mode, when occur bit error, the BITEF (UART_LINSTS[9]) flag will be asserted. If the LINIEN (UART_INTEN[8]) = 1, an interrupt will be generated.                                                                                                                                                                                                                                                                                                                                                           |
| [11]  | <b>LINRXOFF</b> | <b>LIN Receiver Disable Bit</b><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.<br>0 = LIN receiver Enabled.<br>1 = LIN receiver Disabled.<br><b>Note:</b> This bit is only valid when operating in LIN function mode (FUNCSEL (UART_FUNCSEL[1:0]) = 01).                                                                                                                                                                                                                     |
| [10]  | <b>BRKDETEN</b> | <b>LIN Break Detection Enable Bit</b><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.<br>0 = LIN break detection Disabled .<br>1 = LIN break detection Enabled.                                                                                                                                                                                                                                                                                                               |
| [9]   | <b>IDPEN</b>    | <b>LIN ID Parity Enable Bit</b><br>0 = LIN frame ID parity Disabled.<br>1 = LIN frame ID parity Enabled.<br><b>Note1:</b> This bit can be used for LIN master to sending header field (SENDH (UART_LINCTL[8])) = 1 and HSEL (UART_LINCTL[23:22]) = 10 or be used for enable LIN slave received frame ID parity checked.<br><b>Note2:</b> This bit is only used when the operation header transmitter is in HSEL (UART_LINCTL[23:22]) = 10.                                                                                                                                                                                                                               |
| [8]   | <b>SENDH</b>    | <b>LIN TX Send Header Enable Bit</b><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]).<br>0 = Send LIN TX header Disabled.<br>1 = Send LIN TX header Enabled.<br><b>Note1:</b> This bit is shadow bit of LINTXEN (UART_ALTCTL [7]); user can read/write it by setting LINTXEN (UART_ALTCTL [7]) or SENDH (UART_LINCTL [8]).<br><b>Note2:</b> When transmitter header field (it may be "break" or "break + sync" or "break + sync + frame ID" selected by HSEL (UART_LINCTL[23:22]) field) transfer operation finished, this bit will be cleared automatically. |
| [7:5] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [4]   | <b>MUTE</b>     | <b>LIN Mute Mode Enable Bit</b><br>0 = LIN mute mode Disabled.<br>1 = LIN mute mode Enabled.<br><b>Note:</b> The exit from mute mode condition and each control and interactions of this field are explained in 6.15.5.9 (LIN slave mode).                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [3]   | <b>SLVDUEN</b>  | <b>LIN Slave Divider Update Method Enable Bit</b><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><b>Note1:</b> This bit only is valid in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1).<br><b>Note2:</b> This bit used for LIN Slave Automatic Resynchronization mode. (for Non-Automatic Resynchronization mode, this bit should be kept cleared)                                                                                                                                    |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                | <b>Note3:</b> The control and interactions of this field are explained in 6.15.5.9 (Slave mode with automatic resynchronization).                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [2] | <b>SLVAREN</b> | <b>LIN Slave Automatic Resynchronization Mode Enable Bit</b><br>0 = LIN automatic resynchronization Disabled.<br>1 = LIN automatic resynchronization Enabled.<br><b>Note1:</b> This bit only is valid in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1).<br><b>Note2:</b> When operation in Automatic Resynchronization mode, the baud rate setting must be mode2 (BAUDM1 (UART_BAUD [29]) and BAUDM0 (UART_BAUD [28]) must be 1).<br><b>Note3:</b> The control and interactions of this field are explained in 6.15.5.9 (Slave mode with automatic resynchronization). |
| [1] | <b>SLVHDEN</b> | <b>LIN Slave Header Detection Enable Bit</b><br>0 = LIN slave header detection Disabled.<br>1 = LIN slave header detection Enabled.<br><b>Note1:</b> This bit is only valid in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1).<br><b>Note2:</b> In LIN function mode, when detect header field (break + sync + frame ID), SLVHDETF (UART_LINSTS [0]) flag will be asserted. If the LINIEN (UART_INTEN[8]) = 1, an interrupt will be generated.                                                                                                                          |
| [0] | <b>SLVEN</b>   | <b>LIN Slave Mode Enable Bit</b><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>x=0,1 | UARTx_BA+0x38 | R/W | UART LIN 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 |    |    |    |          |          | BITEF  | BRKDETF  |
| 7        | 6  | 5  | 4  | 3        | 2        | 1      | 0        |
| Reserved |    |    |    | SLVSYNCF | SLVIDPEF | SLVHEF | SLVHDETF |

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [9]     | <b>BITEF</b>    | <p><b>Bit Error Detect Status Flag</b></p> <p>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.</p> <p>When occur bit error, if the LINIEN (UART_INTEN[8]) = 1, an interrupt will be generated.</p> <p>0 = Bit error not detected.<br/>1 = Bit error detected.</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> This bit is only valid when enable bit error detection function (BITERREN (UART_LINCTL [12]) = 1).</p>                                                                                           |
| [8]     | <b>BRKDETF</b>  | <p><b>LIN Break Detection Flag</b></p> <p>This bit is set by hardware when a break is detected and be cleared by writing 1 to it through software.</p> <p>0 = LIN break not detected.<br/>1 = LIN break detected.</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> This bit is only valid when LIN break detection function is enabled (BRKDETEN (UART_LINCTL[10]) =1).</p>                                                                                                                                                                                                                                                                    |
| [7:4]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [3]     | <b>SLVSYNCF</b> | <p><b>LIN Slave Sync Field</b></p> <p>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.</p> <p>0 = The current character is not at LIN sync state.<br/>1 = The current character is at LIN sync state.</p> <p><b>Note1:</b> This bit is only valid in LIN Slave mode (SLVEN(UART_LINCTL[0]) = 1).</p> <p><b>Note2:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note3:</b> When writing 1 to it, hardware will reload the initial baud rate and re-search a new</p> |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | frame header.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [2] | <b>SLVIDPEF</b> | <p><b>LIN Slave ID Parity Error Flag</b></p> <p>This bit is set by hardware when received frame ID parity is not correct.<br/>0 = No active.<br/>1 = Received frame ID parity is not correct.</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> 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]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [1] | <b>SLVHEF</b>   | <p><b>LIN Slave Header Error Flag</b></p> <p>This bit is set by hardware when a LIN header error is detected in LIN slave mode and be cleared by writing 1 to it. The header errors include “break delimiter is too short (less than 0.5 bit time)”, “frame error in sync field or Identifier field”, “sync field data is not 0x55 in Non-Automatic Resynchronization mode”, “sync field deviation error with Automatic Resynchronization mode”, “sync field measure time-out with Automatic Resynchronization mode” and “LIN header reception time-out”.</p> <p>0 = LIN header error not detected.<br/>1 = LIN header error detected.</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> This bit is only valid when UART is operated in LIN slave mode (SLVEN (UART_LINCTL [0]) = 1) and enables LIN slave header detection function (SLVHDEN (UART_LINCTL [1])).</p> |
| [0] | <b>SLVHDETF</b> | <p><b>LIN Slave Header Detection Flag</b></p> <p>This bit is set by hardware when a LIN header is detected in LIN slave mode and be cleared by writing 1 to it.</p> <p>0 = LIN header not detected.<br/>1 = LIN header detected (break + sync + frame ID).</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> 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])).</p> <p><b>Note3:</b> When enable ID parity check IDPEN (UART_LINCTL [9]), if hardware detect complete header (“break + sync + frame ID”), the SLVHDETF will be set whether the frame ID correct or not.</p>                                                                                                                                                                                            |

UART Baud Rate Compensation Register (UART\_BRCOMP)

| Register                         | Offset        | R/W | Description                          |  |  |  | Reset Value |
|----------------------------------|---------------|-----|--------------------------------------|--|--|--|-------------|
| UART_BRCOM<br>P<br>x=0,1,2,3,4,5 | UARTx_BA+0x3C | R/W | UART Baud Rate Compensation Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | BRCOMPDEC   | <b>Baud Rate Compensation Decrease</b><br>0 = 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      | <b>Baud Rate Compensation Patten</b><br>These 9-bits are used to define the relative bit is compensated or not.<br>BRCOMP[7:0] is used to define the compensation of UART_DAT[7:0] and BRCOM[8] is used to define the parity bit. |

UART Wake-up Control Register (UART\_WKCTL)

| Register                    | Offset        | R/W | Description                   |  |  |  | Reset Value |
|-----------------------------|---------------|-----|-------------------------------|--|--|--|-------------|
| UART_WKCTL<br>x=0,1,2,3,4,5 | UARTx_BA+0x40 | R/W | UART Wake-up Control Register |  |  |  | 0x0000_0000 |

|          |    |    |          |           |          |         |         |
|----------|----|----|----------|-----------|----------|---------|---------|
| 31       | 30 | 29 | 28       | 27        | 26       | 25      | 24      |
| Reserved |    |    |          |           |          |         |         |
| 23       | 22 | 21 | 20       | 19        | 18       | 17      | 16      |
| 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    | <b>Received Data FIFO Reached Threshold Time-out Wake-up Enable Bit</b><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><b>Note1:</b> When the system is in Power-down mode, Received Data FIFO reached threshold time-out will wake up system from Power-down mode.<br><b>Note2:</b> It is suggested the function is enabled when the WKRFRTEN (UART_WKCTL[2]) is set to 1. |
| [3]    | WKRS485EN   | <b>RS-485 Address Match (AAD Mode) Wake-up Enable Bit</b><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><b>Note1:</b> When the system is in Power-down mode, RS-485 Address Match will wake-up system from Power-down mode.<br><b>Note2:</b> 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    | <b>Received Data FIFO Reached Threshold Wake-up Enable Bit</b><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><b>Note:</b> When the system is in Power-down mode, Received Data FIFO reached threshold will wake-up system from Power-down mode.                                                                                                                                              |
| [1]    | WKDATEN     | <b>Incoming Data Wake-up Enable Bit</b><br>0 = Incoming data wake-up system function Disabled.<br>1 = Incoming data wake-up system function Enabled.<br><b>Note:</b> When the system is in Power-down mode, incoming data will wake-up system from Power-down mode.                                                                                                                                                                                                                                          |
| [0]    | WKCTSEN     | <b>nCTS Wake-up Enable Bit</b><br>0 = nCTS Wake-up system function Disabled.<br>1 = nCTS Wake-up system function Enabled.                                                                                                                                                                                                                                                                                                                                                                                    |

|  |  |                                                                                                                       |
|--|--|-----------------------------------------------------------------------------------------------------------------------|
|  |  | <b>Note:</b> 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>x=0,1,2,3,4,5 | UARTx_BA+0x44 | R/W | UART Wake-up Status Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [4]    | TOUTWKF     | <p><b>Received Data FIFO Threshold Time-out Wake-up Flag</b></p> <p>This bit is set if chip wake-up from power-down state by Received Data FIFO Threshold Time-out wake-up.</p> <p>0 = Chip stays in power-down state.</p> <p>1 = Chip wake-up from power-down state by Received Data FIFO reached threshold time-out.</p> <p><b>Note1:</b> If WKTOUTEN (UART_WKCTL[4]) is enabled, the Received Data FIFO reached threshold time-out wake-up cause this bit is set to '1'.</p> <p><b>Note2:</b> This bit can be cleared by writing '1' to it.</p> |
| [3]    | RS485WKF    | <p><b>RS-485 Address Match (AAD Mode) Wake-up Flag</b></p> <p>This bit is set if chip wake-up from power-down state by RS-485 Address Match (AAD mode).</p> <p>0 = Chip stays in power-down state.</p> <p>1 = Chip wake-up from power-down state by RS-485 Address Match (AAD mode) wake-up.</p> <p><b>Note1:</b> If WKRS485EN (UART_WKCTL[3]) is enabled, the RS-485 Address Match (AAD mode) wake-up cause this bit is set to '1'.</p> <p><b>Note2:</b> This bit can be cleared by writing '1' to it.</p>                                        |
| [2]    | RFRTWKF     | <p><b>Received Data FIFO Reached Threshold Wake-up Flag</b></p> <p>This bit is set if chip wake-up from power-down state by Received Data FIFO reached threshold wake-up .</p> <p>0 = Chip stays in power-down state.</p> <p>1 = Chip wake-up from power-down state by Received Data FIFO Reached Threshold wake-up.</p> <p><b>Note1:</b> If WKRFRTEN (UART_WKCTL[2]) is enabled, the Received Data FIFO Reached Threshold wake-up cause this bit is set to '1'.</p>                                                                               |

|     |               |                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |               | <b>Note2:</b> This bit can be cleared by writing '1' to it.                                                                                                                                                                                                                                                                                                                                           |
| [1] | <b>DATWKF</b> | <b>Incoming Data Wake-up Flag</b><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.<br><b>Note1:</b> If WKDATEN (UART_WKCTL[1]) is enabled, the Incoming Data wake-up cause this bit is set to '1'.<br><b>Note2:</b> This bit can be cleared by writing '1' to it. |
| [0] | <b>CTSWKF</b> | <b>nCTS Wake-up Flag</b><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><b>Note1:</b> If WKCTSEN (UART_WKCTL[0]) is enabled, the nCTS wake-up cause this bit is set to '1'.<br><b>Note2:</b> 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_DWKCO<br>MP<br>x=0,1,2,3,4,5 | UARTx_BA+0x48 | R/W | UART Incoming Data Wake-up Compensation Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                    |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                          |
| [15:0]  | STCOMP      | <p><b>Start Bit Compensation Value</b></p> <p>These bits field indicate how many clock cycle selected by UART_CLK do the UART controller can get the 1<sup>st</sup> bit (start bit) when the device is wake-up from Power-down mode.</p> <p><b>Note:</b> It is valid only when WKDATEN (UART_WKCTL[1]) is set.</p> |

## 6.16 Ethernet MAC Controller (EMAC)

### 6.16.1 Overview

This chip provides an Ethernet MAC Controller (EMAC) for Network application. The Ethernet MAC controller consists of IEEE 802.3/Ethernet protocol engine with internal CAM function for recognizing Ethernet MAC addresses, Transmit-FIFO, Receive-FIFO, TX/RX state machine controller, time stamping engine for IEEE 1588, Magic Packet parsing engine and status controller. The EMAC supports both the MII and RMII (Reduced MII) interface to connect with external Ethernet PHY.

### 6.16.2 Features

- Supports IEEE Std. 802.3 CSMA/CD protocol
- Supports Ethernet frame time stamping for IEEE Std. 1588 – 2002 protocol
- Supports both half and full duplex for 10 Mbps or 100 Mbps operation
- Supports RMII interface
- Supports MII Management function to control external Ethernet PHY
- Supports pause and remote pause function for flow control
- Supports long frame (more than 1518 bytes) and short frame (less than 64 bytes) reception
- Supports 16 entries CAM function for Ethernet MAC address recognition
- Supports Magic Packet recognition to wake system up from Power-down mode
- Supports 256 bytes transmit FIFO and 256 bytes receive FIFO
- Supports DMA function

### 6.16.3 Block Diagram



Figure 6.16-1 Ethernet MAC Controller Block Diagram

#### **6.16.4 Basic Configuration**

#### **6.16.4.1 EMAC Basic Configuration**

- Clock source Configuration
    - Select the clock divider number of MDC clock on EMACDIV (CLK\_CLKDIV3[21:16]).
    - Enable EMAC clock in EMACCKEN (CLK\_AHBCLK[5]).
  - Reset Configuration
    - Reset EMAC controller in EMACRST (SYS\_IPRST0[5]).
  - Pin Configuration

| Group | Pin Name       | GPIO        | MFP  |
|-------|----------------|-------------|------|
| EMAC  | EMAC_RMII_MDC  | PB.11, PE.8 | MFP3 |
|       | EMAC_RMII_MDIO | PB.10, PE.9 | MFP3 |
|       | EMAC_RMII_RXD0 | PC.7        | MFP3 |
|       |                | PB.4        | MFP4 |
|       | EMAC_RMII_RXD1 | PC.6        | MFP3 |

|                  |             |      |
|------------------|-------------|------|
|                  | PB.3        | MFP4 |
| EMAC_RMII_CRSDV  | PA.7        | MFP3 |
|                  | PB.2        | MFP4 |
| EMAC_RMII_RXERR  | PA.6        | MFP3 |
|                  | PB.1        | MFP4 |
| EMAC_RMII_TXD0   | PB.9, PE.10 | MFP3 |
| EMAC_RMII_TXD1   | PB.8, PE.11 | MFP3 |
| EMAC_RMII_TXEN   | PB.7, PE.12 | MFP3 |
| EMAC_PPS         | PB.6, PE.13 | MFP3 |
| EMAC_RMII_REFCLK | PC.8        | MFP3 |
|                  | PB.5        | MFP4 |

## 6.16.5 Functional Description

### 6.16.5.1 Arbiter

In the EMAC, there are two different bus requests, RXREQ and TXREQ respectively. Arbiter does the arbitration between the RXREQ and TXREQ, and then decides which one can request the AHB bus. The arbitration results are shown in Table 6.16-1.

| RXREQ | TXREQ | Granted                                                                                                |
|-------|-------|--------------------------------------------------------------------------------------------------------|
| 0     | 0     | Neither TXDMA nor RXDMA granted.                                                                       |
| 0     | 1     | TXDMA granted.                                                                                         |
| 1     | 0     | RXDMA granted.                                                                                         |
| 1     | 1     | If TXFIFO valid data byte count is less than RXFIFO free space byte count, TXDMA granted.              |
| 1     | 1     | If RXFIFO free space byte count is less than or equal to TXFIFO valid space byte count, RXDMA granted. |

Table 6.16-1 Arbiter Arbitration Results

### 6.16.5.2 TXDMA State Machine

The TXDMA state machine transfers data from the system memory to the internal 256 bytes transmit FIFO through the AHB master. Then, the TXDMA state machine will request the transmit MAC to send the data out. During the transmission process, the TXDMA will fetch the transmit descriptor first. Through the buffer address field of the transmit descriptor, the TXDMA fetch the frame data from the system and store it into the internal 256 bytes transmit FIFO. Then, the transmit MAC will read frame data from the transmit FIFO and send the frame out. After the finish of the frame transmission, the TXDMA updates the transmit status of current frame and write the transmit descriptor back to the system memory to indicate the frame transmission has finished.

### 6.16.5.3 RXDMA State Machine

The RXDMA state machine transfers data from the internal 256 bytes receiving FIFO to the system memory through AHB master. During the receiving process, the RXDMA will fetch the received descriptor first. Through the buffer address field of the received descriptor, the RXDMA will know memory space which is allocated to store the incoming frame. After the received MAC indicates there is a new incoming frame, the RXDMA starts to transfer the frame data from the internal received FIFO to the system memory. After the receiving process has finished, the RXDMA will update the receiving

status of current frame and write the received descriptor back to system memory to indicate a new incoming frame is in the system memory.

#### 6.16.5.4 Flow Control

This block implements the flow control function while EMAC operates in the full duplex mode. The flow control function is defined in the IEEE 802.3 Std. chapter 31. The type of flow control frame defined in the IEEE 802.3 Std. is only the PAUSE frame at the moment. The control frame transmission and reception is programmable through the control registers.

To receive a control frame, software must set the bit ACP (Accept Control Packet) of register EMAC\_CTL (MAC Command Register). While a PAUSE frame is received, the flow control function will pause the transmission process after the current transmitting frame has been transmitted out.

To transmit a control frame out, software must program the destination MAC address of control frame into the register pair {EMAC\_CAM13M, EMAC\_CAM13L}, source MAC address into the register pair {EMAC\_CAM14M, EMAC\_CAM14L}, and configure LENGTH, OPCODE and OPERAND of control frame into the register pair {EMAC\_CAM15MSB, EMAC\_CAM15LSB}, and then set the bit SDPZ (EMAC\_CTL[16]). The bit SDPZ (EMAC\_CTL[16]) will be cleared while the control frame has been transmitted out.

#### 6.16.5.5 MII Management State Machine

The MII management function of EMAC is compliant to IEEE 802.3 Std. Through the MII management interface, software can access the control and status registers of the external PHY chip. Two programmable registers EMAC\_MIIMDAT (MAC MII Management Data Register) and EMAC\_MIIMCTL (MAC MII Management Data Control and Address Register) are for MII management function. Set the bit BUSY (EMAC\_MIIMCTL[17]) will trigger the MII management state machine. After the MII management cycle is finished, the BUSY bit will be cleared automatically.

#### 6.16.5.6 Media Access Control (MAC)

The function of Ethernet MAC fully meets the requirements defined by the IEEE802.3u specification. Figure 6.16-2 describes the frame structure and the operation of the transmission and receiving.

The transmission data frame sent from the transmit DMA will be encapsulated by the MAC before transmitting onto the MII bus. The sent data will be assembled with the preamble, the start frame delimiter (SFD), the frame check sequence and the padding for enforcing those less than 64 bytes to meet the minimum size frame and CRC sequence. The outgoing frame format will be as follows.

|                        |          |    |    |    |    |    |         |       |       |     |      |
|------------------------|----------|----|----|----|----|----|---------|-------|-------|-----|------|
| 110101010 --- 10101010 | 10101011 | d0 | d1 | d2 | -- | dn | Padding | CRC31 | CRC30 | --- | CRC0 |
|------------------------|----------|----|----|----|----|----|---------|-------|-------|-----|------|

Figure 6.16-2 Ethernet Frame Format

As mentioned by the above format, the preamble is a consecutive 7-byte long with the pattern "10101010" and the SFD is a one byte 10101011 data. The padding data will be all 0 value if the sent data frame is less than 64 bytes. The padding disable function specified in the bit P of the transmit descriptor is used to control if the MAC needs to pad data at the end of frame data or not when the transmitted data frame is less than 64 bytes. The padding data will not be appended if the padding disable bit is set to be high. The bits CRC0 ... CRC31 are the 32 bits cyclic redundancy check (CRC) sequence. The CRC encoding is defined by the following polynomial specified by the IEEE802.3. This 32 bits CRC appending function will be disabled if the Inhibit CRC of the transmission descriptor is set to high.

The MAC also performs many other transmission functions specified by the IEEE802.3, including the inter-frame spacing function, collision detection, collision enforcement, collision back off and retransmission. The collision back-off timer is a function of the integer slot time, 512-bit time. The number of slot times to delay between the current transmission attempt to the next attempt is determined by a uniformly distributed random integer algorithm specified by the IEEE802.3. The MAC performs the receive functions specified by the IEEE 802.3 including the address recognition function, the frame check sequence validation, the frame disassembly, framing and collision filtering.

#### 6.16.5.7 Time Stamping Engine for IEEE 1588

The EMAC supports a time stamping engine for IEEE Std. 1588. In this time stamping engine, a 64-bit counter implemented to generate the reference timing, the registers EMAC\_TSSEC and ETSLSR.

In frame transmission, if TSEN (EMAC\_TSCTL[0]) and TTSEN of TXDES 0 (TXDMA Descriptor Word 0) are both high, EMAC would store the 64-bit reference timing value to TXDES 1 (TXDMA Descriptor Word 1) and TXDES 2 (TXDMA Descriptor Word 2) when frame transmission completed.

In frame reception, if TSEN (EMAC\_TSCTL[0]) is high, EMAC would store the 64-bit reference timing value to RXDES 1 (RXDMA Descriptor Word 1) and RXDES 3 (RXDMA Descriptor Word 3) when the frame reception finished.

Figure 6.16-2 describes how the 64-bit counter works to generate the reference timing.

The 64-bit counter formed by two 32-bit counters, the EMAC\_TSSEC and EMAC\_TSSUBSEC, a updated using the EMAC's input reference clock, the HCLK. Two difference methods, controlled by TSMODE (EMAC\_TSCTL[3]), implemented to increase 32-bit EMAC\_TSSUBSEC counter by value configured in register EMAC\_TSINC. When TSMODE (EMAC\_TSCTL[3]) is low, TSLSR counter increased in every clock. When TSMODE (EMAC\_TSCTL[3]) is high, TSLSR counter increased only when accumulator is overflow.



Table 6.16-2 64-bit Reference Timing Counter

#### 6.16.5.8 Magic Packet Parsing Engine

The EMAC supports a Magic packet parsing engine for recognizing Magic packet. The Magic packet is a broadcast frame which payload includes 6 bytes of 0xFF, followed by 16 repetitions of 48-bit MAC address defined by registers EMAC\_CAM0M and EMAC\_CAM0L.

The WOLEN (EMAC\_CTL[6]) controls if the Magic packet parsing engine enabled. If WOLEN (EMAC\_CTL[6]) is high, EMAC will set bit WOLIF (EMAC\_INTSTS[15]) high to indicate Magic packet received. At the same time, EMAC generates an event to wake system up from Power-down mode. If WOLIEN of register MIEN is high, EMAC generates an RX interrupt to CPU simultaneously.

#### 6.16.5.9 DMA Descriptors Data Structure

A link-list data structure named as descriptor is used to keep the control, status and data information

of each frame. Through the descriptor, CPU and EMAC exchange the information for frame reception and transmission.

Two different descriptors defined in EMAC. One named as RXDMA descriptor for frame reception and the other named as TXDMA descriptor for frame transmission. Each RXDMA or TXDMA descriptor consists of four words. The descriptor keeps the much control, status information and the details of descriptor are described in 6.16.5.10 RXDMA descriptor data structure and 6.16.5.11 TXDMA descriptor data structure.

#### 6.16.5.10 RXDMA Descriptor Data Structure

The RXDMA descriptor consists of four 32-bit words. The data structure of RXDMA descriptor is shown in Figure 6.16-3.



Figure 6.16-3 RXDMA Descriptor Data Structure

**RXDES 0: RXDMA Descriptor Word 0**

The RXDMA descriptor word 0 contains a descriptor ownership indicator, receive frame status, and receive frame byte count. The detailed description of RXDES 0 is shown below.

| 31    | 30       | 29     | 28     | 27   | 26       | 25     | 24   |
|-------|----------|--------|--------|------|----------|--------|------|
| Owner | Reserved |        |        |      |          |        |      |
| 23    | 22       | 21     | 20     | 19   | 18       | 17     | 16   |
| RTSAS | RPIF     | ALIEIF | RXGDIF | LPIF | Reserved | CRCEIF | RXIF |
| 15    | 14       | 13     | 12     | 11   | 10       | 9      | 8    |
| RBC   |          |        |        |      |          |        |      |
| 7     | 6        | 5      | 4      | 3    | 2        | 1      | 0    |
| RBC   |          |        |        |      |          |        |      |

| Bits    | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | Owner    | <b>Ownership</b><br>The ownership field defines which one, the CPU or EMAC, is the owner of each RX descriptor. Only the owner has right to modify the RX descriptor and the others can read the RX descriptor only.<br>If the O=1'b1 indicates the EMAC RXDMA is the owner of RX descriptor and the RX descriptor is available for frame reception. After the frame reception completed, EMAC RXDMA modified ownership field to 1'b0.<br>If the O=1'b0 indicates the CPU is the owner of RX descriptor. After the CPU completed the frame processing, it modified the ownership field to 1'b1 and released the RX descriptor to EMAC RXDMA.<br>0 = The owner is CPU.<br>1 = The owner is EMAC. |
| [30:24] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [23]    | RTSAS    | <b>RX Time Stamp Active Status</b><br>This bit is to indicate the time stamping circuit stamped this incoming frame successfully. When this bit set high, RX Descriptor Word 1 and RX Descriptor Word 3 keep the time stamp value recorded when this incoming frame is received completely.<br>0 = RX Descriptor Word 1 and RX Descriptor Word 3 does not keep the time stamp value.<br>1 = RX Descriptor Word 1 and RX Descriptor Word 3 keep the time stamp value.                                                                                                                                                                                                                            |
| [22]    | RPIF     | <b>Runt Packet</b><br>The RPIF indicates the frame stored in the data buffer pointed by RX descriptor is a short frame (frame length is less than 64 bytes).<br>0 = The frame is not a short frame.<br>1 = The frame is a short frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [21]    | ALIEIF   | <b>Alignment Error</b><br>The ALIEIF indicates the frame stored in the data buffer pointed by RX descriptor is not a multiple of byte.<br>0 = The frame is a multiple of byte.<br>1 = The frame is not a multiple of byte.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|        |                 |                                                                                                                                                                                                                                                                                                                          |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [20]   | <b>RXGDIF</b>   | <b>Frame Reception Complete</b><br>The RXGDIF indicates the frame reception has completed and stored in the data buffer pointed by RX descriptor.<br>0 = The frame reception does not complete yet.<br>1 = The frame reception completed.                                                                                |
| [19]   | <b>LPIF</b>     | <b>Long Packet Interrupt Flag</b><br>The LPIF indicates the frame stored in the data buffer pointed by RX descriptor is a long frame (frame length is greater than 1518 bytes).<br>0 = The frame is not a long frame.<br>1 = The frame is a long frame.                                                                  |
| [18]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                |
| [17]   | <b>CRCEIF</b>   | <b>CRC Error</b><br>The CRCEIF indicates the frame stored in the data buffer pointed by RX descriptor incurred CRC error.<br>0 = The frame does not incur CRC error.<br>1 = The frame incurred CRC error.                                                                                                                |
| [16]   | <b>RXIF</b>     | <b>Receive Interrupt</b><br>The RXIF indicates the frame stored in the data buffer pointed by RX descriptor caused an interrupt condition.<br>0 = The frame does not cause an interrupt.<br>1 = The frame caused an interrupt.                                                                                           |
| [15:0] | <b>RBC</b>      | <b>Receive Byte Count</b><br>The RBC indicates the byte count of the frame stored in the data buffer pointed by RX descriptor. The four bytes CRC field is also included in the receive byte count. But if the STRIPCRC (EMAC_CTL[5]) is enabled, the four bytes CRC field will be excluded from the receive byte count. |

**RXDES 1: RXDMA Descriptor Word 1**

The RXDMA descriptor word 1 contains the received frame buffer starting address or time stamp least significant 32-bit value. The detailed description of RXDES 1 is shown below.

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

| Bits   | Field        | Description                                                                                                      |
|--------|--------------|------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>RXBSA</b> | <b>Receive Buffer Starting Address</b><br>The RXBSA is the buffer starting address to store the received packet. |

Table 6.16-3 RXDMA Descriptor Word 1 (TSEN (EMAC\_TSCTL[0]) is 0)

| Bits   | Field           | Description                                                                                                                                                                                                                          |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>TSSUBSEC</b> | <b>Time Stamp Sub-Second</b><br>If TSEN (EMAC_TSCTL[0]) enabled, Ethernet MAC controller would store time stamp least significant 32-bit value, register ETSLSR, into this field when it writes back RX Descriptor to system memory. |

Table 6.16-4 RXDMA Descriptor Word 1 (TSEN (EMAC\_TSCTL[0]) is 1)

**RXDES 2: RXDMA Descriptor Word 2**

The RXDMA descriptor word 2 currently is reserved.

|          |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| Reserved |    |    |    |    |    |    |    |
| 23       | 22 | 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   | Field    | Description |
|--------|----------|-------------|
| [31:0] | Reserved | Reserved.   |

Table 6.16-5 RXDMA Descriptor Word 2

**RXDES 3: RXDMA Descriptor Word 3**

The RXDMA descriptor word 3 contains the next RXDMA descriptor starting address or time stamp most significant 32-bit value. The detailed description of RXDES 3 is shown below.

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

| Bits   | Field  | Description                                                                                                                                                                                               |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | NRXDSA | <b>Next RX Descriptor Starting Address</b><br>NRXDSA is the starting address of the next RX descriptor. When Ethernet MAC controller fetches the next RX descriptor, it ignores the bits [1:0] of NRXDSA. |

Table 6.16-6 RXDMA Descriptor Word 3 (TSEN (EMAC\_TSCTL[0]) is 0)

| Bits   | Field | Description                                                                                                                                                                                                                    |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TSSEC | <b>Time Stamp Second</b><br>If TSEN (EMAC_TSCTL[0]) enabled, Ethernet MAC controller would store time stamp most significant 32-bit value, register ETSMR, into this field when it writes back RX Descriptor to system memory. |

Table 6.16-7 RXDMA Descriptor Word 3 (TSEN (EMAC\_TSCTL[0]) is 1)

#### 6.16.5.11 TxDMA Descriptor Data Structure

The TxDMA descriptor consists of four 32-bit words. The data structure of TxDMA descriptor is shown in Figure 6.16-4.



Figure 6.16-4 TxDMA Descriptor Data Structure

**TXDES 0: TXDMA Descriptor Word 0**

The TXDMA descriptor word 0 contains a descriptor ownership indicator. In addition, it also contains control bits for transmit frame padding, CRC append, interrupt enable and time stamping control. The detailed description of TXDES 0 is shown below.

|          |          |    |    |       |       |        |       |
|----------|----------|----|----|-------|-------|--------|-------|
| 31       | 30       | 29 | 28 | 27    | 26    | 25     | 24    |
| Owner    | Reserved |    |    |       |       |        |       |
| 23       | 22       | 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 |          |    |    | TTSEN | INTEN | CRCAPP | PADEN |

| Bits   | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | Owner    | <b>Ownership</b><br>The ownership field defines which one, the CPU or EMAC, is the owner of each TX descriptor. Only the owner has right to modify the TX descriptor and the other can read the TX descriptor only.<br>If the O=1'b1 indicates the EMAC TXDMA is the owner of TX descriptor and the TX descriptor is available for frame transmission. After the frame transmission completed, EMAC TXDMA modify ownership field to 1'b0 and return the ownership of TX descriptor to CPU.<br>If the O=1'b0 indicates the CPU is the owner of TX descriptor. After the CPU prepares new frame to wait transmission, it modifies the ownership field to 1'b1 and releases the TX descriptor to EMAC TXDMA.<br>0 = The owner is CPU.<br>1 = The owner is EMAC. |
| [30:4] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [3]    | TTSEN    | <b>TX Time Stamp Enable Bit</b><br>When this bit set high and IEEE 1588 PTP function is also enabled, the embedded time stamping circuit would stamp this frame when SFD of frame is transmitted out on MII/RMII.<br>0 = IEEE 1588 time stamp function Disabled for this frame.<br>1 = IEEE 1588 time stamp function Enabled for this frame.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [2]    | INTEN    | <b>Transmit Interrupt Enable Bit</b><br>The INTEN controls the interrupt trigger circuit after the frame transmission completed. If the INTEN enabled, the EMAC will trigger interrupt after frame transmission completed. Otherwise, the interrupt doesn't be triggered.<br>0 = Frame transmission interrupt masked.<br>1 = Frame transmission interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                           |
| [1]    | CRCAPP   | <b>CRC Append</b><br>The CRCAPP control the CRC append during frame transmission. If CRCAPP is enabled, the 4-bytes CRC checksum will be appended to frame at the end of frame transmission.<br>0 = 4-bytes CRC appending Disabled.<br>1 = 4-bytes CRC appending Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|     |              |                                                                                                                                                                                                                                                                      |
|-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | <b>PADEN</b> | <b>Padding Enable Bit</b><br>The PADEN control the PAD bits appending while the length of transmission frame is less than 60 bytes. If PADEN is enabled, EMAC does the padding automatically.<br>0 = PAD bits appending Disabled.<br>1 = PAD bits appending Enabled. |
|-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Table 6.16-8 TXDMA Descriptor Word 0

**TXDES 1: TXDMA Descriptor Word 1**

The TXDMA descriptor word 1 contains the transmit frame buffer starting address or time stamp least significant 32-bit value. The detailed description of TXDES 1 is shown below.

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

| Bits   | Field | Description                                                                                                               |
|--------|-------|---------------------------------------------------------------------------------------------------------------------------|
| [31:2] | TXBSA | <b>Transmit Buffer Starting Address</b><br>The TXBSA is the starting address of buffer where transmit packet data stored. |

Table 6.16-9 TXDMA Descriptor Word 1 (TSEN (EMAC\_TSCTL[0]) is 0)

| Bits   | Field    | Description                                                                                                                                                                                                                                                                        |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TSSUBSEC | <b>Time Stamp Sub-Second</b><br>If TSEN (EMAC_TSCTL[0]) and TTSEN of TX Descriptor word 0 both enabled, Ethernet MAC controller would store time stamp least significant 32-bit value, register EMAC_TSSUBSEC, into this field when it writes back TX Descriptor to system memory. |

Table 6.16-10 TXDMA Descriptor Word 1 (TSEN (EMAC\_TSCTL[0]) is 1)

**TXDES 2: TXDMA Descriptor Word 2**

The TXDMA descriptor word 2 contains transmit frame status, and transmit frame byte count. The detailed description of TXDES 2 is shown below.

| 31     | 30      | 29    | 28      | 27     | 26       | 25       | 24     |
|--------|---------|-------|---------|--------|----------|----------|--------|
| COLCNT |         |       |         | TTSAS  | SQE      | TXPAUSED | TXHALT |
| 23     | 22      | 21    | 20      | 19     | 18       | 17       | 16     |
| LCIF   | TXABTIF | NCSIF | EXDEFIF | TXCPIF | Reserved | DEF      | TXIF   |
| 15     | 14      | 13    | 12      | 11     | 10       | 9        | 8      |
| TBC    |         |       |         |        |          |          |        |
| 7      | 6       | 5     | 4       | 3      | 2        | 1        | 0      |
| TBC    |         |       |         |        |          |          |        |

| Bits    | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | COLCNT   | <b>Collision Count</b><br>The COLCNT indicates the how many collisions found consecutively during a packet transmission. If the packet incurred 16 consecutive collisions during transmission, the COLCNT is 0x0 and bit TXABTIF is set high.                                                                                                                                                                                                                |
| [27]    | TTSAS    | <b>TX Time Stamp Active Status</b><br>This bit is to indicate the time stamping circuit stamped this frame successfully. When this bit set high, TX Descriptor Word 1 and TX Descriptor Word 3 keep the time stamp value recorded when SFD of frame is transmitted out on MII/RMII.<br>0 = TX Descriptor Word 1 and TX Descriptor Word 3 does not keep the time stamp value.<br>1 = TX Descriptor Word 1 and TX Descriptor Word 3 keep the time stamp value. |
| [26]    | SQE      | <b>SQE Error</b><br>The SQE indicates the SQE error found at end of packet transmission on 10Mbps half-duplex mode. The SQE error check will only be done while both bit SQECHKEN (EMAC_CTL[17]) is enabled and EMAC is operating on 10Mbps half-duplex mode.<br>0 = No SQE error found at end of packet transmission.<br>1 = SQE error found at end of packet transmission.                                                                                 |
| [25]    | TXPAUSED | <b>Transmission Paused</b><br>The TXPAUSED indicates the next normal packet transmission process will be paused temporarily because EMAC received a PAUSE control frame, or software sets the bit SDPZ (EMAC_MCM[16]) and enables EMAC to transmit a PAUSE control frame out.<br>0 = Next normal packet transmission process continue normally.<br>1 = Next normal packet transmission process paused.                                                       |
| [24]    | TXHALT   | <b>Transmission Halted</b><br>The TXHALT indicates the next normal packet transmission process will be halted because the bit TXON (EMAC_CTL[8]) is disabled by software.<br>0 = Next normal packet transmission process continue normally.<br>1 = Next normal packet transmission process halted.                                                                                                                                                           |

|        |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23]   | <b>LCIF</b>     | <b>Late Collision</b><br>The LCIF indicates the collision found in the outside of 64 bytes collision window. This means after the 64 bytes of a frame has been transmitted out to the network, the collision still found. The late collision check will only be done while EMAC is operating on half-duplex mode.<br>0 = No collision found in the outside of 64 bytes collision window.<br>1 = Collision found in the outside of 64 bytes collision window.                                |
| [22]   | <b>TXABTIF</b>  | <b>Transmission Abort</b><br>The TXABTIF indicates the packet incurred 16 consecutive collisions during transmission, and then the transmission process for this packet is aborted. The transmission abort is only available while EMAC is operating on half-duplex mode.<br>0 = Packet does not incur 16 consecutive collisions during transmission.<br>1 = Packet incurred 16 consecutive collisions during transmission.                                                                 |
| [21]   | <b>NCSIF</b>    | <b>No Carrier Sense</b><br>The NCSIF indicates the MII I/F signal CRS does not active at the start of or during the packet transmission. The NCSIF is only available while EMAC is operating on half-duplex mode.<br>0 = CRS signal does not active at the start of or during the packet transmission.<br>1 = CRS signal actives correctly.                                                                                                                                                 |
| [20]   | <b>EXDEFIF</b>  | <b>Defer Exceed</b><br>The EXDEFIF indicates the frame waiting for transmission has deferred over 0.32768ms on 100Mbps mode, or 3.2768ms on 10Mbps mode. The deferral exceed check will only be done while bit NODEF (EMAC_CTL[9]) is disabled, and EMAC is operating on half-duplex mode.<br>0 = Frame waiting for transmission did not defer over 0.32768ms (100Mbps) or 3.2768ms (10Mbps).<br>1 = Frame waiting for transmission deferred over 0.32768ms (100Mbps) or 3.2768ms (10Mbps). |
| [19]   | <b>TXCPIF</b>   | <b>Transmission Complete</b><br>The TXCPIF indicates the packet transmission has completed correctly.<br>0 = The packet transmission does not complete.<br>1 = The packet transmission completed.                                                                                                                                                                                                                                                                                           |
| [18]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [17]   | <b>DEF</b>      | <b>Transmission Deferred</b><br>The DEF indicates the packet transmission has deferred once. The DEF is only available while EMAC is operating on half-duplex mode.<br>0 = Packet transmission does not defer.<br>1 = Packet transmission deferred once.                                                                                                                                                                                                                                    |
| [16]   | <b>TXIF</b>     | <b>Transmit Interrupt</b><br>The TXIF indicates the packet transmission would trigger an interrupt condition.<br>0 = The packet transmission would not trigger an interrupt.<br>1 = The packet transmission would trigger an interrupt.                                                                                                                                                                                                                                                     |
| [15:0] | <b>TBC</b>      | <b>Transmit Byte Count</b><br>The TBC indicates the byte count of the frame stored in the data buffer pointed by TX descriptor for transmission.                                                                                                                                                                                                                                                                                                                                            |

Table 6.16-11 TXDMA Descriptor Word 2

**TXDES 3: TXDMA Descriptor Word 3**

The TXDMA descriptor word 3 contains the next TXDMA descriptor starting address or time stamp most significant 32-bit value. The detailed description of TXDES 3 is shown below.

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

| Bits   | Field  | Description                                                                                                                                                                                               |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | NTXDSA | <b>Next TX Descriptor Starting Address</b><br>NTXDSA is the starting address of the next TX descriptor. When Ethernet MAC controller fetches the next TX descriptor, it ignores the bits [1:0] of NTXDSA. |

Table 6.16-12 TXDMA Descriptor Word 3 (TSEN (EMAC\_TSCTL[0]) is 0)

| Bits   | Field | Description                                                                                                                                                                                                                                                                    |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TSSEC | <b>Time Stamp Second</b><br>If TSEN (EMAC_TSCTL[0]) and TTSEN of TX Descriptor word 0 are both enabled, Ethernet MAC controller would store time stamp most significant 32-bit value, register EMAC_TSSEC, into this field when it writes back TX Descriptor to system memory. |

Table 6.16-13 TXDMA Descriptor Word 3 (TSEN (EMAC\_TSCTL[0]) is 1)

### 6.16.6 Register Map

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

| Register                     | Offset        | R/W | Description                           | Reset Value |
|------------------------------|---------------|-----|---------------------------------------|-------------|
| <b>EMAC Base Address:</b>    |               |     |                                       |             |
| <b>EMAC_BA = 0x4000_B000</b> |               |     |                                       |             |
| <b>EMAC_CAMCTL</b>           | EMAC_BA+0x000 | R/W | CAM Comparison Control Register       | 0x0000_0000 |
| <b>ECAM_CAMEN</b>            | EMAC_BA+0x004 | R/W | CAM Enable Register                   | 0x0000_0000 |
| <b>EMAC_CAM0M</b>            | EMAC_BA+0x008 | R/W | CAM0 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM0L</b>            | EMAC_BA+0x00C | R/W | CAM0 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM1M</b>            | EMAC_BA+0x010 | R/W | CAM1 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM1L</b>            | EMAC_BA+0x014 | R/W | CAM1 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM2M</b>            | EMAC_BA+0x018 | R/W | CAM2 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM2L</b>            | EMAC_BA+0x01C | R/W | CAM2 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM3M</b>            | EMAC_BA+0x020 | R/W | CAM3 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM3L</b>            | EMAC_BA+0x024 | R/W | CAM3 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM4M</b>            | EMAC_BA+0x028 | R/W | CAM4 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM4L</b>            | EMAC_BA+0x02C | R/W | CAM4 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM5M</b>            | EMAC_BA+0x030 | R/W | CAM5 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM5L</b>            | EMAC_BA+0x034 | R/W | CAM5 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM6M</b>            | EMAC_BA+0x038 | R/W | CAM6 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM6L</b>            | EMAC_BA+0x03C | R/W | CAM6 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM7M</b>            | EMAC_BA+0x040 | R/W | CAM7 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM7L</b>            | EMAC_BA+0x044 | R/W | CAM7 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM8M</b>            | EMAC_BA+0x048 | R/W | CAM8 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM8L</b>            | EMAC_BA+0x04C | R/W | CAM8 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM9M</b>            | EMAC_BA+0x050 | R/W | CAM9 Most Significant Word Register   | 0x0000_0000 |
| <b>EMAC_CAM9L</b>            | EMAC_BA+0x054 | R/W | CAM9 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM10M</b>           | EMAC_BA+0x058 | R/W | CAM10 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM10L</b>           | EMAC_BA+0x05C | R/W | CAM10 Least Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM11M</b>           | EMAC_BA+0x060 | R/W | CAM11 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM11L</b>           | EMAC_BA+0x064 | R/W | CAM11 Least Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM12M</b>           | EMAC_BA+0x068 | R/W | CAM12 Most Significant Word Register  | 0x0000_0000 |

|                      |               |     |                                                      |             |
|----------------------|---------------|-----|------------------------------------------------------|-------------|
| <b>EMAC_CAM12L</b>   | EMAC_BA+0x06C | R/W | CAM12 Least Significant Word Register                | 0x0000_0000 |
| <b>EMAC_CAM13M</b>   | EMAC_BA+0x070 | R/W | CAM13 Most Significant Word Register                 | 0x0000_0000 |
| <b>EMAC_CAM13L</b>   | EMAC_BA+0x074 | R/W | CAM13 Least Significant Word Register                | 0x0000_0000 |
| <b>EMAC_CAM14M</b>   | EMAC_BA+0x078 | R/W | CAM14 Most Significant Word Register                 | 0x0000_0000 |
| <b>EMAC_CAM14L</b>   | EMAC_BA+0x07C | R/W | CAM14 Least Significant Word Register                | 0x0000_0000 |
| <b>EMAC_CAM15MSB</b> | EMAC_BA+0x080 | R/W | CAM15 Most Significant Word Register                 | 0x0000_0000 |
| <b>EMAC_CAM15LSB</b> | EMAC_BA+0x084 | R/W | CAM15 Least Significant Word Register                | 0x0000_0000 |
| <b>EMAC_TXDSA</b>    | EMAC_BA+0x088 | R/W | Transmit Descriptor Link List Start Address Register | 0xFFFF_FFFC |
| <b>EMAC_RXDSA</b>    | EMAC_BA+0x08C | R/W | Receive Descriptor Link List Start Address Register  | 0xFFFF_FFFC |
| <b>EMAC_CTL</b>      | EMAC_BA+0x090 | R/W | MAC Control Register                                 | 0x0040_0000 |
| <b>EMAC_MIIMDAT</b>  | EMAC_BA+0x094 | R/W | MII Management Data Register                         | 0x0000_0000 |
| <b>EMAC_MIIMCTL</b>  | EMAC_BA+0x098 | R/W | MII Management Control and Address Register          | 0x0090_0000 |
| <b>EMAC_FIFOCTL</b>  | EMAC_BA+0x09C | R/W | FIFO Threshold Control Register                      | 0x0000_0101 |
| <b>EMAC_TXST</b>     | EMAC_BA+0x0A0 | W   | Transmit Start Demand Register                       | Undefined   |
| <b>EMAC_RXST</b>     | EMAC_BA+0x0A4 | W   | Receive Start Demand Register                        | Undefined   |
| <b>EMAC_MRFL</b>     | EMAC_BA+0x0A8 | R/W | Maximum Receive Frame Control Register               | 0x0000_0800 |
| <b>EMAC_INTEN</b>    | EMAC_BA+0x0AC | R/W | MAC Interrupt Enable Register                        | 0x0000_0000 |
| <b>EMAC_INTSTS</b>   | EMAC_BA+0x0B0 | R/W | MAC Interrupt Status Register                        | 0x0000_0000 |
| <b>EMAC_GENSTS</b>   | EMAC_BA+0x0B4 | R/W | MAC General Status Register                          | 0x0000_0000 |
| <b>EMAC_MPCNT</b>    | EMAC_BA+0x0B8 | R/W | Missed Packet Count Register                         | 0x0000_7FFF |
| <b>EMAC_RPCNT</b>    | EMAC_BA+0x0BC | R   | MAC Receive Pause Count Register                     | 0x0000_0000 |
| <b>EMAC_FRSTS</b>    | EMAC_BA+0x0C8 | R/W | DMA Receive Frame Status Register                    | 0x0000_0000 |
| <b>EMAC_CTXDSA</b>   | EMAC_BA+0x0CC | R   | Current Transmit Descriptor Start Address Register   | 0x0000_0000 |
| <b>EMAC_CTXBSA</b>   | EMAC_BA+0x0D0 | R   | Current Transmit Buffer Start Address Register       | 0x0000_0000 |
| <b>EMAC_CRXDSA</b>   | EMAC_BA+0x0D4 | R   | Current Receive Descriptor Start Address Register    | 0x0000_0000 |
| <b>EMAC_CRXBSA</b>   | EMAC_BA+0x0D8 | R   | Current Receive Buffer Start Address Register        | 0x0000_0000 |
| <b>EMAC_TSCTL</b>    | EMAC_BA+0x100 | R/W | Time Stamp Control Register                          | 0x0000_0000 |
| <b>EMAC_TSSEC</b>    | EMAC_BA+0x110 | R   | Time Stamp Counter Second Register                   | 0x0000_0000 |
| <b>EMAC_TSSUBSEC</b> | EMAC_BA+0x114 | R   | Time Stamp Counter Sub Second Register               | 0x0000_0000 |
| <b>EMAC_TSINC</b>    | EMAC_BA+0x118 | R/W | Time Stamp Increment Register                        | 0x0000_0000 |

|                       |               |     |                                       |             |
|-----------------------|---------------|-----|---------------------------------------|-------------|
| <b>EMAC_TSADDEND</b>  | EMAC_BA+0x11C | R/W | Time Stamp Addend Register            | 0x0000_0000 |
| <b>EMAC_UPDSEC</b>    | EMAC_BA+0x120 | R/W | Time Stamp Update Second Register     | 0x0000_0000 |
| <b>EMAC_UPDSUBSEC</b> | EMAC_BA+0x124 | R/W | Time Stamp Update Sub Second Register | 0x0000_0000 |
| <b>EMAC_ALMSEC</b>    | EMAC_BA+0x128 | R/W | Time Stamp Alarm Second Register      | 0x0000_0000 |
| <b>EMAC_ALMSUBSEC</b> | EMAC_BA+0x12C | R/W | Time Stamp Alarm Sub Second Register  | 0x0000_0000 |

### 6.16.7 Register Description

#### CAM Command Register (EMAC\_CAMCTL)

The EMAC supports CAM function for destination MAC address recognition. The EMAC\_CAMCTL control the CAM comparison function, and unicast, multicast, and broadcast packet reception.

| Register    | Offset        | R/W | Description                     |  |  |  |  | Reset Value |
|-------------|---------------|-----|---------------------------------|--|--|--|--|-------------|
| EMAC_CAMCTL | EMAC_BA+0x000 | R/W | CAM Comparison 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 |    |    | CMPEN | COMPEN | ABP | AMP | AUP |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4]    | CMPEN       | <b>CAM Compare Enable Bit</b><br>The CMPEN controls the enable of CAM comparison function for destination MAC address recognition. If software wants to receive a packet with specific destination MAC address, configures the MAC address into CAM 12~0, then enables that CAM entry and set CMPEN to 1.<br>0 = CAM comparison function for destination MAC address recognition Disabled.<br>1 = CAM comparison function for destination MAC address recognition Enabled.  |
| [3]    | COMPEN      | <b>Complement CAM Comparison Enable Bit</b><br>The COMPEN controls the complement of the CAM comparison result. If the CMPEN and COMPEN are both enabled, the incoming packet with specific destination MAC address configured in CAM entry will be dropped. And the incoming packet with destination MAC address does not configured in any CAM entry will be received.<br>0 = Complement CAM comparison result Disabled.<br>1 = Complement CAM comparison result Enabled. |
| [2]    | ABP         | <b>Accept Broadcast Packet</b><br>The ABP controls the broadcast packet reception. If ABP is enabled, EMAC receives all incoming packet its destination MAC address is a broadcast address.<br>0 = EMAC receives packet depends on the CAM comparison result.<br>1 = EMAC receives all broadcast packets.                                                                                                                                                                   |
| [1]    | AMP         | <b>Accept Multicast Packet</b><br>The AMP controls the multicast packet reception. If AMP is enabled, EMAC receives all incoming packet its destination MAC address is a multicast address.<br>0 = EMAC receives packet depends on the CAM comparison result.<br>1 = EMAC receives all multicast packets.                                                                                                                                                                   |

|     |     |                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [0] | AUP | <b>Accept Unicast Packet</b><br>The AUP controls the unicast packet reception. If AUP is enabled, EMAC receives all incoming packet its destination MAC address is a unicast address.<br>0 = EMAC receives packet depends on the CAM comparison result.<br>1 = EMAC receives all unicast packets. |  |  |  |  |
|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|

### CAMCMR Setting and Comparison Results

Table 6.16-14 is the address recognition result in different CAMCMR configuration. The column Result shows the incoming packet type that can pass the address recognition in specific CAM configuration. The C, U, M and B represents the:

C: Indicates the destination MAC address of incoming packet has been configured in CAM entry.

U: Indicates the incoming packet is a unicast packet.

M: Indicates the incoming packet is a multicast packet.

B: Indicates the incoming packet is a broadcast packet.

| CMPEN | CCAM | AUP | AMP | ABP | Result    |   |   |   |  |
|-------|------|-----|-----|-----|-----------|---|---|---|--|
| 0     | 0    | 0   | 0   | 0   | No Packet |   |   |   |  |
| 0     | 0    | 0   | 0   | 1   | B         |   |   |   |  |
| 0     | 0    | 0   | 1   | 0   | M         |   |   |   |  |
| 0     | 0    | 0   | 1   | 1   | M         | B |   |   |  |
| 0     | 0    | 1   | 0   | 0   | C         | U |   |   |  |
| 0     | 0    | 1   | 0   | 1   | C         | U | B |   |  |
| 0     | 0    | 1   | 1   | 0   | C         | U | M |   |  |
| 0     | 0    | 1   | 1   | 1   | C         | U | M | B |  |
| 0     | 1    | 0   | 0   | 0   | C         | U | M | B |  |
| 0     | 1    | 0   | 0   | 1   | C         | U | M | B |  |
| 0     | 1    | 0   | 1   | 0   | C         | U | M | B |  |
| 0     | 1    | 1   | 0   | 1   | C         | U | M | B |  |
| 0     | 1    | 1   | 0   | 0   | C         | U | M | B |  |
| 0     | 1    | 1   | 1   | 0   | C         | U | M | B |  |
| 1     | 0    | 0   | 0   | 0   | C         |   |   |   |  |
| 1     | 0    | 0   | 0   | 1   | C         | B |   |   |  |
| 1     | 0    | 0   | 1   | 0   | C         | M |   |   |  |
| 1     | 0    | 0   | 1   | 1   | C         | M | B |   |  |
| 1     | 0    | 1   | 0   | 0   | C         | U |   |   |  |

|   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 1 | C | U | B |   |
| 1 | 0 | 1 | 1 | 0 | C | U | M |   |
| 1 | 0 | 1 | 1 | 1 | C | U | M | B |
| 1 | 1 | 0 | 0 | 0 | U | M | B |   |
| 1 | 1 | 0 | 0 | 1 | U | M | B |   |
| 1 | 1 | 0 | 1 | 0 | U | M | B |   |
| 1 | 1 | 0 | 1 | 1 | U | M | B |   |
| 1 | 1 | 1 | 0 | 0 | C | U | M | B |
| 1 | 1 | 1 | 0 | 1 | C | U | M | B |
| 1 | 1 | 1 | 1 | 0 | C | U | M | B |
| 1 | 1 | 1 | 1 | 1 | C | U | M | B |

Table 6.16-14 Different CAMCMR Setting and Type of Received Packet

**CAM Enable Register (ECAM\_CAMEN)**

The ECAM\_CAMEN controls the validation of each CAM entry. Each CAM entry must be enabled first before it participates in the destination MAC address recognition.

| Register          | Offset        | R/W | Description         |  |  |  | Reset Value |
|-------------------|---------------|-----|---------------------|--|--|--|-------------|
| <b>ECAM_CAMEN</b> | EMAC_BA+0x004 | R/W | CAM 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             |
| <b>CAM15EN</b> | <b>CAM14EN</b> | <b>CAM13EN</b> | <b>CAM12EN</b> | <b>CAM11EN</b> | <b>CAM10EN</b> | <b>CAM9EN</b> | <b>CAM8EN</b> |
| 7              | 6              | 5              | 4              | 3              | 2              | 1             | 0             |
| <b>CAM7EN</b>  | <b>CAM6EN</b>  | <b>CAM5EN</b>  | <b>CAM4EN</b>  | <b>CAM3EN</b>  | <b>CAM2EN</b>  | <b>CAM1EN</b> | <b>CAM0EN</b> |

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                           |
| [x]     | <b>CAMxEN</b>   | <p><b>CAM Entry X Enable Bit</b></p> <p>The CAMxEN controls the validation of CAM entry x.</p> <p>The CAM entry 13, 14 and 15 are for PAUSE control frame transmission. If software wants to transmit a PAUSE control frame out to network, the enable bits of these three CAM entries all must be enabled first.</p> <p>0 = CAM entry x Disabled.<br/>1 = CAM entry x Enabled.</p> |

**CAM Entry Register (EMAC\_CAMxMSB, x = 0, 1, 2..14)**

The EMAC is equipped with 16 CAM entries. In these 16 CAM entries, 13 entries (entry 0~12) are to keep destination MAC address for packet recognition, and the other 3 entries (entry 13~15) are for PAUSE control frame transmission. Each CAM entry consists of 6 bytes. Consequently, 2 registers are used for each CAM entry.

For packet recognition, a register pair {EMAC\_CAMxMSB, ECAMxL} represents a CAM entry and can keep a destination MAC address. The corresponding CAM enable bit CAMxEN (ECAM\_CAMEN[x]) is also needed to be enabled. The x can be the 0 to 12.

The register pairs {EMAC\_CAM13M, EMAC\_CAM13L}, {EMAC\_CAM14M, EMAC\_CAM14L} and {EMAC\_CAM15MSB, EMAC\_CAM15LSB} are used for flow control function.

| Register           | Offset        | R/W | Description                          | Reset Value |
|--------------------|---------------|-----|--------------------------------------|-------------|
| <b>EMAC_CAM0M</b>  | EMAC_BA+0x008 | R/W | CAM0 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM1M</b>  | EMAC_BA+0x010 | R/W | CAM1 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM2M</b>  | EMAC_BA+0x018 | R/W | CAM2 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM3M</b>  | EMAC_BA+0x020 | R/W | CAM3 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM4M</b>  | EMAC_BA+0x028 | R/W | CAM4 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM5M</b>  | EMAC_BA+0x030 | R/W | CAM5 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM6M</b>  | EMAC_BA+0x038 | R/W | CAM6 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM7M</b>  | EMAC_BA+0x040 | R/W | CAM7 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM8M</b>  | EMAC_BA+0x048 | R/W | CAM8 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM9M</b>  | EMAC_BA+0x050 | R/W | CAM9 Most Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM10M</b> | EMAC_BA+0x058 | R/W | CAM10 Most Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM11M</b> | EMAC_BA+0x060 | R/W | CAM11 Most Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM12M</b> | EMAC_BA+0x068 | R/W | CAM12 Most Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM13M</b> | EMAC_BA+0x070 | R/W | CAM13 Most Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM14M</b> | EMAC_BA+0x078 | R/W | CAM14 Most Significant Word Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | MACADDR5    | <b>MAC Address Byte 5</b><br>The CAMxM keeps the bit 47~16 of MAC address. The x can be the 0~14. The register pair {EMAC_CAMxM, EMAC_CAMxL} represents a CAM entry and keeps a MAC address.<br>For example, if the MAC address 00-50-BA-33-BA-44 kept in CAM entry 1, the register EMAC_CAM1M is 0x0050_BA33 and EMAC_CAM1L is 0xBA44_0000. |
| [23:16] | MACADDR4    | <b>MAC Address Byte 4</b>                                                                                                                                                                                                                                                                                                                    |
| [15:8]  | MACADDR3    | <b>MAC Address Byte 3</b>                                                                                                                                                                                                                                                                                                                    |
| [7:0]   | MACADDR2    | <b>MAC Address Byte 2</b>                                                                                                                                                                                                                                                                                                                    |

CAM Entry Register (EMAC\_CAMxLSB; x = 0, 1, 2..14)

| Register           | Offset        | R/W | Description                           | Reset Value |
|--------------------|---------------|-----|---------------------------------------|-------------|
| <b>EMAC_CAM0L</b>  | EMAC_BA+0x00C | R/W | CAM0 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM1L</b>  | EMAC_BA+0x014 | R/W | CAM1 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM2L</b>  | EMAC_BA+0x01C | R/W | CAM2 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM3L</b>  | EMAC_BA+0x024 | R/W | CAM3 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM4L</b>  | EMAC_BA+0x02C | R/W | CAM4 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM5L</b>  | EMAC_BA+0x034 | R/W | CAM5 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM6L</b>  | EMAC_BA+0x03C | R/W | CAM6 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM7L</b>  | EMAC_BA+0x044 | R/W | CAM7 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM8L</b>  | EMAC_BA+0x04C | R/W | CAM8 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM9L</b>  | EMAC_BA+0x054 | R/W | CAM9 Least Significant Word Register  | 0x0000_0000 |
| <b>EMAC_CAM10L</b> | EMAC_BA+0x05C | R/W | CAM10 Least Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM11L</b> | EMAC_BA+0x064 | R/W | CAM11 Least Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM12L</b> | EMAC_BA+0x06C | R/W | CAM12 Least Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM13L</b> | EMAC_BA+0x074 | R/W | CAM13 Least Significant Word Register | 0x0000_0000 |
| <b>EMAC_CAM14L</b> | EMAC_BA+0x07C | R/W | CAM14 Least Significant Word Register | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <b>MACADDR1</b> | <b>MAC Address Byte 1</b><br>The CAMxL keeps the bit 15~0 of MAC address. The x can be the 0~14. The register pair {EMAC_CAMxM, EMAC_CAMxL} represents a CAM entry and keeps a MAC address.<br>For example, if the MAC address 00-50-BA-33-BA-44 kept in CAM entry 1, the register EMAC_CAM1M is 0x0050_BA33 and EMAC_CAM1L is 0xBA44_0000. |
| [23:16] | <b>MACADDR0</b> | <b>MAC Address Byte 0</b>                                                                                                                                                                                                                                                                                                                   |

[15:0]

Reserved

Reserved.

CAM Entry Register (EMAC\_CAM15MSB)

| Register      | Offset        | R/W | Description                          | Reset Value |
|---------------|---------------|-----|--------------------------------------|-------------|
| EMAC_CAM15MSB | EMAC_BA+0x080 | R/W | CAM15 Most Significant Word Register | 0x0000_0000 |



| Bits    | Description |                                                                                                             |
|---------|-------------|-------------------------------------------------------------------------------------------------------------|
| [31:16] | LENGTH      | LENGTH Field of PAUSE Control Frame<br>In the PAUSE control frame, a LENGTH field defined and is 0x8808.    |
| [15:0]  | OPCODE      | OP Code Field of PAUSE Control Frame<br>In the PAUSE control frame, an op code field defined and is 0x0001. |

CAM Entry Register (EMAC\_CAM15LSB)

| Register      | Offset        | R/W | Description                           |  |  |  | Reset Value |
|---------------|---------------|-----|---------------------------------------|--|--|--|-------------|
| EMAC_CAM15LSB | EMAC_BA+0x084 | R/W | CAM15 Least Significant Word Register |  |  |  | 0x0000_0000 |

|          |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| OPERAND  |    |    |    |    |    |    |    |
| 23       | 22 | 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] | OPERAND     | <b>Pause Parameter</b><br>In the PAUSE control frame, an OPERAND field defined and controls how much time the destination Ethernet MAC Controller paused. The unit of the OPERAND is a slot time, the 512-bit time. |
| [23:0]  | Reserved    | Reserved.                                                                                                                                                                                                           |

**Transmit Descriptor Link List Start Address Register (EMAC\_TXDSA)**

The TX descriptor defined in EMAC is a link-list data structure. The EMAC\_TXDSA keeps the starting address of this link-list. In other words, the EMAC\_TXDSA keeps the starting address of the 1st TX descriptor. EMAC\_TXDSA must be configured by software before the bit TXON (EMAC\_CTL[8]) is enabled.

| Register   | Offset        | R/W | Description                                          |  |  |  |  | Reset Value |
|------------|---------------|-----|------------------------------------------------------|--|--|--|--|-------------|
| EMAC_TXDSA | EMAC_BA+0x088 | R/W | Transmit Descriptor Link List Start Address Register |  |  |  |  | 0xFFFF_FFFC |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TXDSA       | <b>Transmit Descriptor Link-list Start Address</b><br>The TXDSA keeps the start address of transmit descriptor link-list. If the software enables the bit TXON (EMAC_CTL[8]), the content of TXDSA will be loaded into the current transmit descriptor start address register (EMAC_CTXDSA). The TXDSA does not need to be updated by EMAC. During the operation, EMAC will ignore the bits [1:0] of TXDSA. This means that TX descriptors must locate at word boundary memory address. |

**Receive Descriptor Link List Start Address Register (EMAC\_RXDSA)**

The RX descriptor defined in EMAC is a link-list data structure. The EMAC\_RXDSA keeps the starting address of this link-list. In other words, the EMAC\_RXDSA keeps the starting address of the 1st RX descriptor. EMAC\_RXDSA must be configured by software before the bit RXON (EMAC\_CTL[0]) is enabled.

| Register   | Offset        | R/W | Description                                         |  |  |  |  | Reset Value |
|------------|---------------|-----|-----------------------------------------------------|--|--|--|--|-------------|
| EMAC_RXDSA | EMAC_BA+0x08C | R/W | Receive Descriptor Link List Start Address Register |  |  |  |  | 0xFFFF_FFFC |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | RXDSA       | <b>Receive Descriptor Link-list Start Address</b><br>The RXDSA keeps the start address of receive descriptor link-list. If the S/W enables the bit RXON (EMAC_CTL[0]), the content of RXDSA will be loaded into the current receive descriptor start address register (EMAC_CRXDSA). The RXDSA does not be updated by EMAC. During the operation, EMAC will ignore the bits [1:0] of RXDSA. This means that RX descriptors must locate at word boundary memory address. |

**MAC Control Register (EMAC\_CTL)**

The EMAC\_CTL provides the control information for EMAC. Some command settings affect both frame transmission and reception, such as bit FUDUP (EMAC\_CTL[18]), the full/half duplex mode selection, or bit OPMODE (EMAC\_CTL[20]), the 100/10M bps mode selection. Some command settings control frame transmission and reception separately, like bit TXON (EMAC\_CTL[8]) and RXON (EMAC\_CTL[0]).

| Register | Offset        | R/W | Description          |  |  |  | Reset Value |
|----------|---------------|-----|----------------------|--|--|--|-------------|
| EMAC_CTL | EMAC_BA+0x090 | R/W | MAC Control Register |  |  |  | 0x0040_0000 |

|          |        |          |        |            |       |          |       |
|----------|--------|----------|--------|------------|-------|----------|-------|
| 31       | 30     | 29       | 28     | 27         | 26    | 25       | 24    |
| Reserved |        |          |        |            |       |          | RST   |
| 23       | 22     | 21       | 20     | 19         | 18    | 17       | 16    |
| Reserved | RMIIEN | Reserved | OPMODE | RMIIIRXCTL | FUDUP | SQECHKEN | SDPZ  |
| 15       | 14     | 13       | 12     | 11         | 10    | 9        | 8     |
| Reserved |        |          |        |            |       |          | NODEF |
| 7        | 6      | 5        | 4      | 3          | 2     | 1        | 0     |
| Reserved | WOLEN  | STRIPCRC | AEP    | ACP        | ARP   | ALP      | RXON  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [24]    | RST         | <b>Software Reset</b><br>The RST implements a reset function to make the EMAC return default state. The RST is a self-clear bit. This means after the software reset finished, the RST will be cleared automatically. Enable RST can also reset all control and status registers, exclusive of the control bits RMIIEN (EMAC_CTL[22]), and OPMODE (EMAC_CTL[20]).<br>The EMAC re-initial is necessary after the software reset completed.<br>0 = Software reset completed.<br>1 = Software reset Enabled. |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [22]    | RMIIEN      | <b>RMII Mode Enable Bit</b><br>This bit controls if Ethernet MAC controller connected with off-chip Ethernet PHY by MII interface or RMII interface. The RST (EMAC_CTL[24]) would not affect RMIIEN value.<br>0 = Ethernet MAC controller RMII mode Disabled.<br>1 = Ethernet MAC controller RMII mode Enabled.<br><b>Note:</b> This field must keep 1.                                                                                                                                                   |
| [21]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [20]    | OPMODE      | <b>Operation Mode Selection</b><br>The OPMODE defines that if the EMAC is operating on 10M or 100M bps mode. The RST (EMAC_CTL[24]) would not affect OPMODE value.<br>0 = EMAC operates in 10Mbps mode.<br>1 = EMAC operates in 100Mbps mode.                                                                                                                                                                                                                                                             |

|         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19]    | <b>RMIIRXCTL</b> | <b>RMII RX Control</b><br>The RMIIRXCTL control the receive data sample in RMII mode. It's necessary to set this bit high when RMIIEN (EMAC_CTL[ 22]) is high.<br>0 = RMII RX control Disabled.<br>1 = RMII RX control Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [18]    | <b>FUDUP</b>     | <b>Full Duplex Mode Selection</b><br>The FUDUP controls that if EMAC is operating on full or half duplex mode.<br>0 = EMAC operates in half duplex mode.<br>1 = EMAC operates in full duplex mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [17]    | <b>SQECHKEN</b>  | <b>SQE Checking Enable Bit</b><br>The SQECHKEN controls the enable of SQE checking. The SQE checking is only available while EMAC is operating on 10M bps and half duplex mode. In other words, the SQECHKEN cannot affect EMAC operation, if the EMAC is operating on 100M bps or full duplex mode.<br>0 = SQE checking Disabled while EMAC is operating in 10Mbps and Half Duplex mode.<br>1 = SQE checking Enabled while EMAC is operating in 10Mbps and Half Duplex mode.                                                                                                                                                                                                                 |
| [16]    | <b>SDPZ</b>      | <b>Send PAUSE Frame</b><br>The SDPZ controls the PAUSE control frame transmission.<br>If S/W wants to send a PAUSE control frame out, the CAM entry 13, 14 and 15 must be configured first and the corresponding CAM enable bit of CAMEN register also must be set. Then, set SDPZ to 1 enables the PAUSE control frame transmission.<br><br>The SDPZ is a self-clear bit. This means after the PAUSE control frame transmission has completed, the SDPZ will be cleared automatically.<br><br>It is recommended that only enabling SNDPAUSE while EMAC is operating in Full Duplex mode.<br>0 = PAUSE control frame transmission completed.<br>1 = PAUSE control frame transmission Enabled. |
| [15:10] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [9]     | <b>NODEF</b>     | <b>No Deferral</b><br>The NODEF controls the enable of deferral exceed counter. If NODEF is set to high, the deferral exceed counter is disabled. The NODEF is only useful while EMAC is operating on half duplex mode.<br>0 = The deferral exceed counter Enabled.<br>1 = The deferral exceed counter Disabled.                                                                                                                                                                                                                                                                                                                                                                              |
| [8]     | <b>TXON</b>      | <b>Frame Transmission ON</b><br>The TXON controls the normal packet transmission of EMAC. If the TXON is set to high, the EMAC starts the packet transmission process, including the TX descriptor fetching, packet transmission and TX descriptor modification.<br><br>It is must to finish EMAC initial sequence before enable TXON. Otherwise, the EMAC operation is undefined.<br><br>If the TXON is disabled during EMAC is transmitting a packet out, the EMAC stops the packet transmission process after the current packet transmission finished.<br>0 = Packet transmission process stopped.<br>1 = Packet transmission process started.                                            |
| [7]     | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | <b>WOLEN</b>    | <b>Wake on LAN Enable Bit</b><br>The WOLEN high enables the functionality that Ethernet MAC controller checked if the incoming packet is Magic Packet and wakeup system from Power-down mode.<br>If incoming packet was a Magic Packet and the system was in Power-down, the Ethernet MAC controller would generate a wakeup event to wake system up from Power-down mode.<br>0 = Wake-up by Magic Packet function Disabled.<br>1 = Wake-up by Magic Packet function Enabled.                                                                                                                                              |
| [5] | <b>STRIPCRC</b> | <b>Strip CRC Checksum</b><br>The STRIPCRC controls if the length of incoming packet is calculated with 4 bytes CRC checksum. If the STRIPCRC is set to high, 4 bytes CRC checksum is excluded from length calculation of incoming packet.<br>0 = The 4 bytes CRC checksum is included in packet length calculation.<br>1 = The 4 bytes CRC checksum is excluded in packet length calculation.                                                                                                                                                                                                                              |
| [4] | <b>AEP</b>      | <b>Accept CRC Error Packet</b><br>The AEP controls the EMAC accepts or drops the CRC error packet. If the AEP is set to high, the incoming packet with CRC error will be received by EMAC as a good packet.<br>0 = Ethernet MAC controller dropped the CRC error packet.<br>1 = Ethernet MAC controller received the CRC error packet.                                                                                                                                                                                                                                                                                     |
| [3] | <b>ACP</b>      | <b>Accept Control Packet</b><br>The ACP controls the control frame reception. If the ACP is set to high, the EMAC will accept the control frame. Otherwise, the control frame will be dropped. It is recommended that S/W only enable ACP while EMAC is operating on full duplex mode.<br>0 = Ethernet MAC controller dropped the control frame.<br>1 = Ethernet MAC controller received the control frame.                                                                                                                                                                                                                |
| [2] | <b>ARP</b>      | <b>Accept Runt Packet</b><br>The ARP controls the runt packet, which length is less than 64 bytes, reception. If the ARP is set to high, the EMAC will accept the runt packet.<br>Otherwise, the runt packet will be dropped.<br>0 = Ethernet MAC controller dropped the runt packet.<br>1 = Ethernet MAC controller received the runt packet.                                                                                                                                                                                                                                                                             |
| [1] | <b>ALP</b>      | <b>Accept Long Packet</b><br>The ALP controls the long packet, which packet length is greater than 1518 bytes, reception. If the ALP is set to high, the EMAC will accept the long packet.<br>Otherwise, the long packet will be dropped.<br>0 = Ethernet MAC controller dropped the long packet.<br>1 = Ethernet MAC controller received the long packet.                                                                                                                                                                                                                                                                 |
| [0] | <b>RXON</b>     | <b>Frame Reception ON</b><br>The RXON controls the normal packet reception of EMAC. If the RXON is set to high, the EMAC starts the packet reception process, including the RX descriptor fetching, packet reception and RX descriptor modification.<br>It is necessary to finish EMAC initial sequence before enable RXON. Otherwise, the EMAC operation is undefined.<br>If the RXON is disabled during EMAC is receiving an incoming packet, the EMAC stops the packet reception process after the current packet reception finished.<br>0 = Packet reception process stopped.<br>1 = Packet reception process started. |

**MII Management Data Register (EMAC\_MIIMDAT)**

The EMAC provides MII management function to access the control and status registers of the external PHY. The EMAC\_MIIMDAT register is used to store the data that will be written into the registers of external PHY for write command or the data that is read from the registers of external PHY for read command.

| Register     | Offset        | R/W | Description                  |  |  |  | Reset Value |
|--------------|---------------|-----|------------------------------|--|--|--|-------------|
| EMAC_MIIMDAT | EMAC_BA+0x094 | R/W | MII Management Data Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                     |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                           |
| [15:0]  | DATA        | <b>MII Management Data</b><br>The DATA is the 16 bits data that will be written into the registers of external PHY for MII Management write command or the data from the registers of external PHY for MII Management read command. |

**MII Management Control and Address Register (EMAC\_MIIMCTL)**

The EMAC provides MII management function to access the control and status registers of the external PHY. The EMAC\_MIIMCTL register is used to keep the MII management command information, like the register address, external PHY address, MDC clocking rate, read/write etc.

| Register     | Offset        | R/W | Description                                 |  |  |  | Reset Value |
|--------------|---------------|-----|---------------------------------------------|--|--|--|-------------|
| EMAC_MIIMCTL | EMAC_BA+0x098 | R/W | MII Management Control and Address Register |  |  |  | 0x0090_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [19]    | MDCON       | <b>MDC Clock ON</b><br>The MDC controls the MDC clock generation. If the MDCON is set to high, the MDC clock is turned on.<br>0 = MDC clock off.<br>1 = MDC clock on.                                                                                                                                                                                                                                                                                                                 |
| [18]    | PREAMSP     | <b>Preamble Suppress</b><br>The PREAMSP controls the preamble field generation of MII management frame. If the PREAMSP is set to high, the preamble field generation of MII management frame is skipped.<br>0 = Preamble field generation of MII management frame not skipped.<br>1 = Preamble field generation of MII management frame skipped.                                                                                                                                      |
| [17]    | BUSY        | <b>Busy Bit</b><br>The BUSY controls the enable of the MII management frame generation. If S/W wants to access registers of external PHY, it set BUSY to high and EMAC generates the MII management frame to external PHY through MII Management I/F. The BUSY is a self-clear bit. This means the BUSY will be cleared automatically after the MII management command finished.<br>0 = MII management command generation finished.<br>1 = MII management command generation Enabled. |
| [16]    | WRITE       | <b>Write Command</b><br>The Write defines the MII management command is a read or write.<br>0 = MII management command is a read command.<br>1 = MII management command is a write command.                                                                                                                                                                                                                                                                                           |
| [15:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

|        |                 |                                                                                                                                                     |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| [12:8] | <b>PHYADDR</b>  | <b>PHY Address</b><br>The PHYADDR keeps the address to differentiate which external PHY is the target of the MII management command.                |
| [7:5]  | <b>Reserved</b> | Reserved.                                                                                                                                           |
| [4:0]  | <b>PHYREG</b>   | <b>PHY Register Address</b><br>The PHYREG keeps the address to indicate which register of external PHY is the target of the MII management command. |

### MII Management Function Frame Format

In IEEE Std. 802.3 clause 22.2.4, the MII management function is defined. The MII management function is used for the purpose of controlling the PHY and gathering status from the PHY. The MII management frame format is shown as follow.

|       | Management Frame Fields |    |    |        |       |    |                    |      |
|-------|-------------------------|----|----|--------|-------|----|--------------------|------|
|       | PRE                     | ST | OP | PHYAD  | REGAD | TA | DATA               | IDLE |
| READ  | 1...1                   | 01 | 10 | AAAAAA | RRRRR | Z0 | DDDDDDDDDDDDDDDDDD | Z    |
| WRITE | 1...1                   | 01 | 01 | AAAAAA | RRRRR | 10 | DDDDDDDDDDDDDDDDDD | Z    |

Table 6.16-15 MII Management Frame Format

### MII Management Function Configure Sequence

| Read                                                                                                                                                                                                                                                                                                                                                                                    | Write                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ol style="list-style-type: none"> <li>Set appropriate EMAC_MDCCR.</li> <li>Set PHYADDR and PHYREG.</li> <li>Set Write to 1<b>b</b>0</li> <li>Set bit BUSY (EMAC_MIIMCTL[17]) to 1<b>b</b>1 to send a MII management frame out.</li> <li>Wait BUSY (EMAC_MIIMCTL[17]) to become 1<b>b</b>0.</li> <li>Read data from EMAC_MIIMDAT register.</li> <li>Finish the read command.</li> </ol> | <ol style="list-style-type: none"> <li>Write data to EMAC_MIIMDAT register</li> <li>Set appropriate EMAC_MDCCR.</li> <li>Set PHYADDR and PHYREG.</li> <li>Set Write to 1<b>b</b>1</li> <li>Set bit BUSY (EMAC_MIIMCTL[17]) to 1<b>b</b>1 to send a MII management frame out.</li> <li>Wait BUSY (EMAC_MIIMCTL[17]) to become 1<b>b</b>0.</li> <li>Finish the write command.</li> </ol> |

Table 6.16-16 MII Management Function Configure Sequence

**FIFO Threshold Control Register (EMAC FIFOCTL)**

The EMAC\_FIFOCTL defines the high and low threshold of internal FIFOs, including TXFIFO and RXFIFO. The threshold of internal FIFOs is related to EMAC request generation and when the frame transmission starts. The EMAC\_FIFOCTL also defines the burst length of AHB bus cycle for system memory access.

| Register     | Offset        | R/W | Description                     |  |  |  | Reset Value |
|--------------|---------------|-----|---------------------------------|--|--|--|-------------|
| EMAC_FIFOCTL | EMAC_BA+0x09C | R/W | FIFO Threshold Control Register |  |  |  | 0x0000_0101 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [21:20] | BURSTLEN    | <b>DMA Burst Length</b><br>This defines the burst length of AHB bus cycle while EMAC accesses system memory.<br>00 = 4 words.<br>01 = 8 words.<br>10 = 16 words.<br>11 = 16 words.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [19:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [9:8]   | TXFIFOTH    | <b>TXFIFO Low Threshold</b><br>The TXFIFOTH controls when TxDMA requests internal arbiter for data transfer between system memory and TXFIFO. The TXFIFOTH defines not only the low threshold of TXFIFO, but also the high threshold. The high threshold is the twice of low threshold always. During the packet transmission, if the TXFIFO reaches the high threshold, the TxDMA stops generate request to transfer frame data from system memory to TXFIFO. If the frame data in TXFIFO is less than low threshold, TxDMA starts to transfer frame data from system memory to TXFIFO.<br><br>The TXFIFOTH also defines when the TXMAC starts to transmit frame out to network. The TXMAC starts to transmit the frame out while the TXFIFO first time reaches the high threshold during the transmission of the frame. If the frame data length is less than TXFIFO high threshold, the TXMAC starts to transmit the frame out after the frame data are all inside the TXFIFO.<br><br>00 = Undefined.<br>01 = TXFIFO low threshold is 64B and high threshold is 128B.<br>10 = TXFIFO low threshold is 80B and high threshold is 160B.<br>11 = TXFIFO low threshold is 96B and high threshold is 192B. |
| [7:2]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|       |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0] | RXFIFOTH | <b>RXFIFO Low Threshold</b><br>The RXFIFOTH controls when RXDMA requests internal arbiter for data transfer between RXFIFO and system memory. The RXFIFOTH defines not only the high threshold of RXFIFO, but also the low threshold. The low threshold is the half of high threshold always. During the packet reception, if the RXFIFO reaches the high threshold, the RXDMA starts to transfer frame data from RXFIFO to system memory. If the frame data in RXFIFO is less than low threshold, RXDMA stops to transfer the frame data to system memory.<br>00 = Depend on the burst length setting. If the burst length is 8 words, high threshold is 8 words, too.<br>01 = RXFIFO high threshold is 64B and low threshold is 32B.<br>10 = RXFIFO high threshold is 128B and low threshold is 64B.<br>11 = RXFIFO high threshold is 192B and low threshold is 96B. |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**Transmit Start Demand Register (EMAC\_TXST)**

S/W issues a write command to EMAC\_TXST register to make TxDMA to leave Halt state and continue the frame transmission.

| Register  | Offset        | R/W | Description                    |  |  |  | Reset Value |
|-----------|---------------|-----|--------------------------------|--|--|--|-------------|
| EMAC_TXST | EMAC_BA+0x0A0 | W   | Transmit Start Demand Register |  |  |  | Undefined   |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TXST        | <b>Transmit Start Demand</b><br>If the TX descriptor is not available for use of TxDMA after the TXON (EMAC_CTL[8]) is enabled, the FSM (Finite State Machine) of TxDMA enters the Halt state and the frame transmission is halted. After the S/W has prepared the new TX descriptor for frame transmission, it must issue a write command to EMAC_TXST register to make TxDMA to leave Halt state and continue the frame transmission.<br>The EMAC_TXST is a write only register and read from this register is undefined.<br>The write to EMAC_TXST register takes effect only when TxDMA stayed at Halt state. |

**Receive Start Demand Register (EMAC\_RXST)**

S/W issues a write command to EMAC\_RXST register to make RXDMA to leave Halt state and continue the frame reception.

| Register  | Offset                    | R/W | Description                   |  |  |  | Reset Value |
|-----------|---------------------------|-----|-------------------------------|--|--|--|-------------|
| EMAC_RXST | EMAC_BA+0x0A <sub>4</sub> | W   | Receive Start Demand Register |  |  |  | Undefined   |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | RXST        | <b>Receive Start Demand</b><br>If the RX descriptor is not available for use of RXDMA after the RXON (EMAC_CTL[0]) is enabled, the FSM (Finite State Machine) of RXDMA enters the Halt state and the frame reception is halted. After the S/W has prepared the new RX descriptor for frame reception, it must issue a write command to EMAC_RXST register to make RXDMA to leave Halt state and continue the frame reception.<br>The EMAC_RXST is a write only register and read from this register is undefined.<br>The write to EMAC_RXST register take effect only when RXDMA stayed at Halt state. |

**Maximum Receive Frame Control Register (EMAC\_MRFL)**

The EMAC\_MRFL defines the maximum frame length for a received frame that can be stored in the system memory. It is recommended that only use this register while S/W wants to receive a frame which length is greater than 1518 bytes.

| Register  | Offset        | R/W | Description                            |  |  |  |  | Reset Value |
|-----------|---------------|-----|----------------------------------------|--|--|--|--|-------------|
| EMAC_MRFL | EMAC_BA+0x0A8 | R/W | Maximum Receive Frame Control Register |  |  |  |  | 0x0000_0800 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [15:0]  | MRFL        | <p><b>Maximum Receive Frame Length</b></p> <p>The MRFL defines the maximum frame length for received frame. If the frame length of received frame is greater than MRFL, and bit MFLEIEN (EMAC_INTEN[8]) is also enabled, the bit MFLEIF (EMAC_INTSTS[8]) is set and the RX interrupt is triggered.</p> <p>It is recommended that only use MRFL to qualify the length of received frame while S/W wants to receive a frame which length is greater than 1518 bytes.</p> |

**MAC Interrupt Enable Register (EMAC\_INTEN)**

The EMAC\_INTEN controls the enable of EMAC interrupt status to generate interrupt. Two interrupts, RXIF for frame reception and TXIF for frame transmission, are generated from EMAC to CPU.

| Register   | Offset        | R/W | Description                   |  |  |  | Reset Value |
|------------|---------------|-----|-------------------------------|--|--|--|-------------|
| EMAC_INTEN | EMAC_BA+0x0AC | R/W | MAC Interrupt Enable Register |  |  |  | 0x0000_0000 |

|          |        |          |          |          |         |         |         |
|----------|--------|----------|----------|----------|---------|---------|---------|
| 31       | 30     | 29       | 28       | 27       | 26      | 25      | 24      |
| Reserved |        |          | TSALMIEN | Reserved |         |         | TXBEIEN |
| 23       | 22     | 21       | 20       | 19       | 18      | 17      | 16      |
| TDUIEN   | LCIEN  | TXABTIEN | NCSIEN   | EXDEFIEN | TXCPIEN | TXUDIEN | TXIEN   |
| 15       | 14     | 13       | 12       | 11       | 10      | 9       | 8       |
| WOLIEN   | CFRIEN | Reserved |          | RXBEIEN  | RDUIEN  | DENIEN  | MFLEIEN |
| 7        | 6      | 5        | 4        | 3        | 2       | 1       | 0       |
| MPCOVIEN | RPIEN  | ALIEIEN  | RXGDIEN  | LPIEN    | RXOVIEN | CRCEIEN | RXIEN   |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [28]    | TSALMIEN    | <b>Time Stamp Alarm Interrupt Enable Bit</b><br>The TSALMIEN controls the TSALMIF (EMAC_INTSTS[28]) interrupt generation. If TSALMIF (EMAC_INTSTS[28]) is set, and both TSALMIEN and TXIEN (EMAC_INTEN[16]) enabled, the EMAC generates the TX interrupt to CPU. If TSALMIEN or TXIEN (EMAC_INTEN[16]) disabled, no TX interrupt generated to CPU even the TXTSALMIF (EMAC_INTEN[28]) is set.<br>0 = TXTSALMIF (EMAC_INTSTS[28]) trigger TX interrupt Disabled.<br>1 = TXTSALMIF (EMAC_INTSTS[28]) trigger TX interrupt Enabled.     |
| [27:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [24]    | TXBEIEN     | <b>Transmit Bus Error Interrupt Enable Bit</b><br>The TXBEIEN controls the TXBEIF (EMAC_INTSTS[24]) interrupt generation. If TXBEIF (EMAC_INTSTS[24]) is set, and both TXBEIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If TXBEIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the TXBEIF (EMAC_INTSTS[24]) is set.<br>0 = TXBEIF (EMAC_INTSTS[24]) trigger TX interrupt Disabled.<br>1 = TXBEIF (EMAC_INTSTS[24]) trigger TX interrupt Enabled.      |
| [23]    | TDUIEN      | <b>Transmit Descriptor Unavailable Interrupt Enable Bit</b><br>The TDUIEN controls the TDUIF (EMAC_INTSTS[23]) interrupt generation. If TDUIF (EMAC_INTSTS[23]) is set, and both TDUIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If TDUIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the TDUIF (EMAC_INTSTS[23]) is set.<br>0 = TDUIF (EMAC_INTSTS[23]) trigger TX interrupt Disabled.<br>1 = TDUIF (EMAC_INTSTS[23]) trigger TX interrupt Enabled. |

|      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [22] | <b>LCIEN</b>    | <b>Late Collision Interrupt Enable Bit</b><br>The LCIEN controls the LCIF (EMAC_INTSTS[22]) interrupt generation. If LCIEN (EMAC_INTSTS[22]) is set, and both LCIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If LCIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the LCIF (EMAC_INTSTS[22]) is set.<br>0 = LCIF (EMAC_INTSTS[22]) trigger TX interrupt Disabled.<br>1 = LCIF (EMAC_INTSTS[22]) trigger TX interrupt Enabled.                        |
| [21] | <b>TXABTIEN</b> | <b>Transmit Abort Interrupt Enable Bit</b><br>The TXABTIEN controls the TXABTIF (EMAC_INTSTS[21]) interrupt generation. If TXABTIF (EMAC_INTSTS[21]) is set, and both TXABTIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If TXABTIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the TXABTIF (EMAC_INTSTS[21]) is set.<br>0 = TXABTIF (EMAC_INTSTS[21]) trigger TX interrupt Disabled.<br>1 = TXABTIF (EMAC_INTSTS[21]) trigger TX interrupt Enabled. |
| [20] | <b>NCSIEN</b>   | <b>No Carrier Sense Interrupt Enable Bit</b><br>The NCSIEN controls the NCSIF (EMAC_INTSTS[20]) interrupt generation. If NCSIEN (EMAC_INTSTS[20]) is set, and both NCSIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If NCSIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the NCSIEN (EMAC_INTSTS[20]) is set.<br>0 = NCSIEN (EMAC_INTSTS[20]) trigger TX interrupt Disabled.<br>1 = NCSIEN (EMAC_INTSTS[20]) trigger TX interrupt Enabled.           |
| [19] | <b>EXDEFIEN</b> | <b>Defer Exceed Interrupt Enable Bit</b><br>The EXDEFIEN controls the EXDEFIF (EMAC_INTSTS[19]) interrupt generation. If EXDEFIF (EMAC_INTSTS[19]) is set, and both EXDEFIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If EXDEFIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the EXDEFIF (EMAC_INTSTS[19]) is set.<br>0 = EXDEFIF (EMAC_INTSTS[19]) trigger TX interrupt Disabled.<br>1 = EXDEFIF (EMAC_INTSTS[19]) trigger TX interrupt Enabled.   |
| [18] | <b>TXCPIEN</b>  | <b>Transmit Completion Interrupt Enable Bit</b><br>The TXCPIEN controls the TXCPIF (EMAC_INTSTS[18]) interrupt generation. If TXCPIF (EMAC_INTSTS[18]) is set, and both TXCPIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If TXCPIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the TXCPIF (EMAC_INTSTS[18]) is set.<br>0 = TXCPIF (EMAC_INTSTS[18]) trigger TX interrupt Disabled.<br>1 = TXCPIF (EMAC_INTSTS[18]) trigger TX interrupt Enabled.    |
| [17] | <b>TXUDIEN</b>  | <b>Transmit FIFO Underflow Interrupt Enable Bit</b><br>The TXUDIEN controls the TXUDIF (EMAC_INTSTS[17]) interrupt generation. If TXUDIF (EMAC_INTSTS[17]) is set, and both TXUDIEN and TXIEN (EMAC_INTEN[16]) are enabled, the EMAC generates the TX interrupt to CPU. If TXUDIEN or TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated to CPU even the TXUDIF (EMAC_INTSTS[17]) is set.<br>0 = TXUDIF (EMAC_INTSTS[17]) TX interrupt Disabled.<br>1 = TXUDIF (EMAC_INTSTS[17]) TX interrupt Enabled.                |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]    | <b>TXIEN</b>    | <b>Transmit Interrupt Enable Bit</b><br>The TXIEN controls the TX interrupt generation.<br>If TXIEN is enabled and TXIF (EMAC_INTSTS[16]) is high, EMAC generates the TX interrupt to CPU. If TXIEN is disabled, no TX interrupt is generated to CPU even any status bit of EMAC_INTSTS[24:17] set and the corresponding bit of EMAC_INTEN is enabled. In other words, if S/W wants to receive TX interrupt from EMAC, this bit must be enabled. And, if S/W doesn't want to receive any TX interrupt from EMAC, disables this bit.<br>0 = TXIF (EMAC_INTSTS[16]) is masked and TX interrupt generation Disabled.<br>1 = TXIF (EMAC_INTSTS[16]) is not masked and TX interrupt generation Enabled. |
| [15]    | <b>WOLIEN</b>   | <b>Wake on LAN Interrupt Enable Bit</b><br>The WOLIEN controls the WOLIF (EMAC_INTSTS[15]) interrupt generation. If WOLIF (EMAC_INTSTS[15]) is set, and both WOLIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If WOLIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the WOLIF (EMAC_INTSTS[15]) is set.<br>0 = WOLIF (EMAC_INTSTS[15]) trigger RX interrupt Disabled.<br>1 = WOLIF (EMAC_INTSTS[15]) trigger RX interrupt Enabled.                                                                                                                                                                                     |
| [14]    | <b>CFRIEN</b>   | <b>Control Frame Receive Interrupt Enable Bit</b><br>The CFRIEN controls the CFRIF (EMAC_INTSTS[14]) interrupt generation. If CFRIF (EMAC_INTSTS[14]) is set, and both CFRIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If CFRIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the CFRIF (EMAC_INTSTS[14]) register is set.<br>0 = CFRIF (EMAC_INTSTS[14]) trigger RX interrupt Disabled.<br>1 = CFRIF (EMAC_INTSTS[14]) trigger RX interrupt Enabled.                                                                                                                                                                  |
| [13:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [11]    | <b>RXBEIEN</b>  | <b>Receive Bus Error Interrupt Enable Bit</b><br>The RXBEIEN controls the RXBEIF (EMAC_INTSTS[11]) interrupt generation. If RXBEIF (EMAC_INTSTS[11]) is set, and both RXBEIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If RXBEIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the RXBEIF (EMAC_INTSTS[11]) is set.<br>0 = RXBEIF (EMAC_INTSTS[11]) trigger RX interrupt Disabled.<br>1 = RXBEIF (EMAC_INTSTS[11]) trigger RX interrupt Enabled.                                                                                                                                                                       |
| [10]    | <b>RDUIEN</b>   | <b>Receive Descriptor Unavailable Interrupt Enable Bit</b><br>The RDUIEN controls the RDUIF (EMAC_INTSTS[10]) interrupt generation. If RDUIF (EMAC_INTSTS[10]) is set, and both RDUIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If RDUIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the RDUIF (EMAC_MIOSTA[10]) register is set.<br>0 = RDUIF (EMAC_INTSTS[10]) trigger RX interrupt Disabled.<br>1 = RDUIF (EMAC_INTSTS[10]) trigger RX interrupt Enabled.                                                                                                                                                         |
| [9]     | <b>DENIEN</b>   | <b>DMA Early Notification Interrupt Enable Bit</b><br>The DENIEN controls the DENIF (EMAC_INTSTS[9]) interrupt generation. If DENIF (EMAC_INTSTS[9]) is set, and both DENIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If DENIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the DENIF (EMAC_INTSTS[9]) is set.<br>0 = TDENIF (EMAC_INTSTS[9]) trigger RX interrupt Disabled.<br>1 = TDENIF (EMAC_INTSTS[9]) trigger RX interrupt Enabled.                                                                                                                                                                             |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8] | <b>MFLEIEN</b>  | <b>Maximum Frame Length Exceed Interrupt Enable Bit</b><br>The MFLEIEN controls the MFLEIF (EMAC_INTSTS[8]) interrupt generation. If MFLEIF (EMAC_INTSTS[8]) is set, and both MFLEIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If MFLEIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the MFLEIF (EMAC_INTSTS[8]) is set.<br>0 = MFLEIF (EMAC_INTSTS[8]) trigger RX interrupt Disabled.<br>1 = MFLEIF (EMAC_INTSTS[8]) trigger RX interrupt Enabled.         |
| [7] | <b>MPCOVIEN</b> | <b>Miss Packet Counter Overrun Interrupt Enable Bit</b><br>The MPCOVIEN controls the MPCOVIF (EMAC_INTSTS[7]) interrupt generation. If MPCOVIF (EMAC_INTSTS[7]) is set, and both MPCOVIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If MPCOVIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the MPCOVIF (EMAC_INTSTS[7]) is set.<br>0 = MPCOVIF (EMAC_INTSTS[7]) trigger RX interrupt Disabled.<br>1 = MPCOVIF (EMAC_INTSTS[7]) trigger RX interrupt Enabled. |
| [6] | <b>RPIEN</b>    | <b>Runt Packet Interrupt Enable Bit</b><br>The RPIEN controls the RPIF (EMAC_INTSTS[6]) interrupt generation. If RPIF (EMAC_INTSTS[6]) is set, and both RPIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If RPIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the RPIF (EMAC_INTSTS[6]) is set.<br>0 = RPIF (EMAC_INTSTS[6]) trigger RX interrupt Disabled.<br>1 = RPIF (EMAC_INTSTS[6]) trigger RX interrupt Enabled.                                         |
| [5] | <b>ALIEIEN</b>  | <b>Alignment Error Interrupt Enable Bit</b><br>The ALIEIEN controls the ALIEIF (EMAC_INTSTS[5]) interrupt generation. If ALIEIF (EMAC_INTSTS[5]) is set, and both ALIEIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If ALIEIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the ALIEIF (EMAC_INTSTS[5]) is set.<br>0 = ALIEIF (EMAC_INTSTS[5]) trigger RX interrupt Disabled.<br>1 = ALIEIF (EMAC_INTSTS[5]) trigger RX interrupt Enabled.                     |
| [4] | <b>RXGDIEN</b>  | <b>Receive Good Interrupt Enable Bit</b><br>The RXGDIEN controls the RXGDFIF (EMAC_INTSTS[4]) interrupt generation. If RXGDFIF (EMAC_INTSTS[4]) is set, and both RXGDIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If RXGDIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the RXGDFIF (EMAC_INTSTS[4]) is set.<br>0 = RXGDFIF (EMAC_INTSTS[4]) trigger RX interrupt Disabled.<br>1 = RXGDFIF (EMAC_INTSTS[4]) trigger RX interrupt Enabled.                   |
| [3] | <b>LPIEN</b>    | <b>Long Packet Interrupt Enable Bit</b><br>The LPIEN controls the LPIF (EMAC_INTSTS[3]) interrupt generation. If LPIF (EMAC_INTSTS[3]) is set, and both LPIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If LPIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the LPIF (EMAC_INTSTS[3]) is set.<br>0 = LPIF (EMAC_INTSTS[3]) trigger RX interrupt Disabled.<br>1 = LPIF (EMAC_INTSTS[3]) trigger RX interrupt Enabled.                                         |
| [2] | <b>RXOVien</b>  | <b>Receive FIFO Overflow Interrupt Enable Bit</b><br>The RXOVien controls the RXOVIF (EMAC_INTSTS[2]) interrupt generation. If RXOVIF (EMAC_INTSTS[2]) is set, and both RXOVien and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If RXOVien or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the RXOVIF (EMAC_INTSTS[2]) is set.<br>0 = RXOVIF (EMAC_INTSTS[2]) trigger RX interrupt Disabled.<br>1 = RXOVIF (EMAC_INTSTS[2]) trigger RX interrupt Enabled.               |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | <b>CRCEIEN</b> | <b>CRC Error Interrupt Enable Bit</b><br>The CRCEIEN controls the CRCEIF (EMAC_INTSTS[1]) interrupt generation. If CRCEIEN (EMAC_INTSTS[1]) is set, and both CRCEIEN and RXIEN (EMAC_INTEN[0]) are enabled, the EMAC generates the RX interrupt to CPU. If CRCEIEN or RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated to CPU even the CRCEIF (EMAC_INTSTS[1]) is set.<br>0 = CRCEIF (EMAC_INTSTS[1]) trigger RX interrupt Disabled.<br>1 = CRCEIF (EMAC_INTSTS[1]) trigger RX interrupt Enabled.                                                                                                                                                                              |
| [0] | <b>RXIEN</b>   | <b>Receive Interrupt Enable Bit</b><br>The RXIEN controls the RX interrupt generation.<br>If RXIEN is enabled and RXIF (EMAC_INTSTS[0]) is high, EMAC generates the RX interrupt to CPU. If RXIEN is disabled, no RX interrupt is generated to CPU even any status bit EMAC_INTSTS[15:1] is set and the corresponding bit of EMAC_INTEN is enabled. In other words, if S/W wants to receive RX interrupt from EMAC, this bit must be enabled. And, if S/W doesn't want to receive any RX interrupt from EMAC, disables this bit.<br>0 = RXIF (EMAC_INTSTS[0]) is masked and RX interrupt generation Disabled.<br>1 = RXIF (EMAC_INTSTS[0]) is not masked and RX interrupt generation Enabled. |

**MAC Interrupt Status Register (EMAC\_INTSTS)**

The EMAC\_INTSTS keeps much EMAC statuses, such as frame transmission, reception status and internal FIFO status. The statuses kept in EMAC\_INTSTS will trigger the reception or transmission interrupt. The EMAC\_INTSTS is a write clear register and write 1 to corresponding bit clears the status and also clears the interrupt.

| Register    | Offset        | R/W | Description                   |  |  |  | Reset Value |
|-------------|---------------|-----|-------------------------------|--|--|--|-------------|
| EMAC_INTSTS | EMAC_BA+0x0B0 | R/W | MAC Interrupt Status Register |  |  |  | 0x0000_0000 |

|          |       |          |         |          |        |        |        |
|----------|-------|----------|---------|----------|--------|--------|--------|
| 31       | 30    | 29       | 28      | 27       | 26     | 25     | 24     |
| Reserved |       |          | TSALMIF | Reserved |        |        | TXBEIF |
| 23       | 22    | 21       | 20      | 19       | 18     | 17     | 16     |
| TDUIF    | LCIF  | TXABTIF  | NCSIF   | EXDEFIF  | TXCPIF | TXUDIF | TXIF   |
| 15       | 14    | 13       | 12      | 11       | 10     | 9      | 8      |
| WOLIF    | CFRIF | Reserved |         | RXBEIF   | RDUIF  | DENIF  | MFLEIF |
| 7        | 6     | 5        | 4       | 3        | 2      | 1      | 0      |
| MPCOVIF  | RPIF  | ALIEIF   | RXGdif  | LPIF     | RXOVIF | CRCEIF | RXIF   |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [28]    | TSALMIF     | <b>Time Stamp Alarm Interrupt</b><br>The TSALMIF high indicates the EMAC_TSSEC register value equals to EMAC_ALMSEC register and EMAC_TSSUBSEC register value equals to register EMAC_ALMSUBSEC.<br>If TSALMIF is high and TSALMIEN (EMAC_INTEN[28]) enabled, the TXIF will be high. Write 1 to this bit clears the TSALMIF status.<br>0 = EMAC_TSSEC did not equal EMAC_ALMSEC or EMAC_TSSUBSEC did not equal EMAC_ALMSUBSEC.<br>1 = EMAC_TSSEC equals EMAC_ALMSEC and EMAC_TSSUBSEC equals EMAC_ALMSUBSEC. |
| [27:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [24]    | TXBEIF      | <b>Transmit Bus Error Interrupt</b><br>The TXBEIF high indicates the memory controller replies ERROR response while EMAC access system memory through TXDMA during packet transmission process. Reset EMAC is recommended while TXBEIF status is high.<br>If the TXBEIF is high and TXBEIEN (EMAC_INTEN[24]) is enabled, the TXIF will be high. Write 1 to this bit clears the TXBEIF status.<br>0 = No ERROR response is received.<br>1 = ERROR response is received.                                       |

|      |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23] | <b>TDUIF</b>   | <p><b>Transmit Descriptor Unavailable Interrupt</b></p> <p>The TDUIF high indicates that there is no available TX descriptor for packet transmission and TxDMA will stay at Halt state. Once, the TxDMA enters the Halt state, S/W must issues a write command to TSDR register to make TxDMA leave Halt state while new TX descriptor is available.</p> <p>If the TDUIF is high and TDUIEN (EMAC_INTEN[23]) is enabled, the TXIF will be high. Write 1 to this bit clears the TDUIF status.</p> <p>0 = TX descriptor is available.<br/>1 = TX descriptor is unavailable.</p>                                                                                              |
| [22] | <b>LCIF</b>    | <p><b>Late Collision Interrupt</b></p> <p>The LCIF high indicates the collision occurred in the outside of 64 bytes collision window. This means after the 64 bytes of a frame has been transmitted out to the network, the collision still occurred. The late collision check will only be done while EMAC is operating on half-duplex mode. If the LCIF is high and LCIEN (EMAC_INTEN[22]) is enabled, the TXIF will be high. Write 1 to this bit clears the LCIF status.</p> <p>0 = No collision occurred in the outside of 64 bytes collision window.<br/>1 = Collision occurred in the outside of 64 bytes collision window.</p>                                      |
| [21] | <b>TXABTIF</b> | <p><b>Transmit Abort Interrupt</b></p> <p>The TXABTIF high indicates the packet incurred 16 consecutive collisions during transmission, and then the transmission process for this packet is aborted. The transmission abort is only available while EMAC is operating on half-duplex mode.</p> <p>If the TXABTIF is high and TXABTIEN (EMAC_INTEN[21]) is enabled, the TXIF will be high. Write 1 to this bit clears the TXABTIF status.</p> <p>0 = Packet does not incur 16 consecutive collisions during transmission.<br/>1 = Packet incurred 16 consecutive collisions during transmission.</p>                                                                       |
| [20] | <b>NCSIF</b>   | <p><b>No Carrier Sense Interrupt</b></p> <p>The NCSIF high indicates the MII I/F signal CRS does not active at the start of or during the packet transmission. The NCSIF is only available while EMAC is operating on half-duplex mode. If the NCSIEN (EMAC_INTEN[20]) is enabled, the TXIF will be high. Write 1 to this bit clears the NCSIF status.</p> <p>0 = CRS signal actives correctly.<br/>1 = CRS signal does not active at the start of or during the packet transmission.</p>                                                                                                                                                                                  |
| [19] | <b>EXDEFIF</b> | <p><b>Defer Exceed Interrupt</b></p> <p>The EXDEFIF high indicates the frame waiting for transmission has deferred over 0.32768ms on 100Mbps mode, or 3.2768ms on 10Mbps mode. The deferral exceed check will only be done while bit NODEF of MCMDR is disabled, and EMAC is operating on half-duplex mode.</p> <p>If the EXDEFIF is high and EXDEFIEN (EMAC_INTEN[19]) is enabled, the TXIF will be high. Write 1 to this bit clears the EXDEFIF status.</p> <p>0 = Frame waiting for transmission has not deferred over 0.32768ms (100Mbps) or 3.2768ms (10Mbps).<br/>1 = Frame waiting for transmission has deferred over 0.32768ms (100Mbps) or 3.2768ms (10Mbps).</p> |
| [18] | <b>TXCPIF</b>  | <p><b>Transmit Completion Interrupt</b></p> <p>The TXCPIF indicates the packet transmission has completed correctly.</p> <p>If the TXCPIF is high and TXCPIEN (EMAC_INTEN[18]) is enabled, the TXIF will be high. Write 1 to this bit clears the TXCPIF status.</p> <p>0 = The packet transmission not completed.<br/>1 = The packet transmission has completed.</p>                                                                                                                                                                                                                                                                                                       |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]    | <b>TXUDIF</b>   | <b>Transmit FIFO Underflow Interrupt</b><br>The TXUDIF high indicates the TXFIFO underflow occurred during packet transmission. While the TXFIFO underflow occurred, the EMAC will retransmit the packet automatically without S/W intervention. If the TXFIFO underflow occurred often, it is recommended that modify TXFIFO threshold control, the TXFIFOTH of FFTCR register, to higher level.<br>If the TXUDIF is high and TXUDIEN (EMAC_INTEN[17]) is enabled, the TXIF will be high. Write 1 to this bit clears the TXUDIF status.<br>0 = No TXFIFO underflow occurred during packet transmission.<br>1 = TXFIFO underflow occurred during packet transmission.                                                                                                                                                                                                                              |
| [16]    | <b>TXIF</b>     | <b>Transmit Interrupt</b><br>The TXIF indicates the TX interrupt status.<br>If TXIF high and its corresponding enable bit, TXIEN (EMAC_INTEN[16]), is also high indicates the EMAC generates TX interrupt to CPU. If TXIF is high but TXIEN (EMAC_INTEN[16]) is disabled, no TX interrupt is generated.<br>The TXIF is logic OR result of bit logic AND result of EMAC_INTSTS[28:17] and EMAC_INTEN[28:17]. In other words, if any bit of EMAC_INTSTS[28:17] is high and its corresponding enable bit in EMAC_INTEN[28:17] is also enabled, the TXIF will be high. Because the TXIF is a logic OR result, clears EMAC_INTSTS[28:17] makes TXIF be cleared, too.<br>0 = No status bit in EMAC_INTSTS[28:17] is set or no enable bit in EMAC_INTEN[28:17] is enabled.<br>1 = At least one status in EMAC_INTSTS[28:17] is set and its corresponding enable bit in EMAC_INTEN[28:17] is enabled, too. |
| [15]    | <b>WOLIF</b>    | <b>Wake on LAN Interrupt Flag</b><br>The WOLIF high indicates EMAC receives a Magic Packet. The CFRIF only available while system is in Power-down mode and WOLEN is set high.<br>If the WOLIF is high and WOLIEN (EMAC_INTEN[15]) is enabled, the RXIF will be high. Write 1 to this bit clears the WOLIF status.<br>0 = The EMAC does not receive the Magic Packet.<br>1 = The EMAC receives a Magic Packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [14]    | <b>CFRIF</b>    | <b>Control Frame Receive Interrupt</b><br>The CFRIF high indicates EMAC receives a flow control frame. The CFRIF only available while EMAC is operating on full duplex mode.<br>If the CFRIF is high and CFRIEN (EMAC_INTEN[14]) is enabled, the RXIF will be high. Write 1 to this bit clears the CFRIF status.<br>0 = The EMAC does not receive the flow control frame.<br>1 = The EMAC receives a flow control frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [13:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [11]    | <b>RXBEIF</b>   | <b>Receive Bus Error Interrupt</b><br>The RXBEIF high indicates the memory controller replies ERROR response while EMAC access system memory through RXDMA during packet reception process. Reset EMAC is recommended while RXBEIF status is high.<br>If the RXBEIF is high and RXBEIEN (EMAC_INTEN[11]) is enabled, the RXIF will be high. Write 1 to this bit clears the RXBEIF status.<br>0 = No ERROR response is received.<br>1 = ERROR response is received.                                                                                                                                                                                                                                                                                                                                                                                                                                 |

|      |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10] | RDUIF   | <b>Receive Descriptor Unavailable Interrupt</b><br>The RDUIF high indicates that there is no available RX descriptor for packet reception and RXDMA will stay at Halt state. Once, the RXDMA enters the Halt state, S/W must issues a write command to RSDR register to make RXDMA leave Halt state while new RX descriptor is available.<br>If the RDUIF is high and RDUIEN (EMAC_INTEN[10]) is enabled, the RXIF will be high. Write 1 to this bit clears the RDUIF status.<br>0 = RX descriptor is available.<br>1 = RX descriptor is unavailable.           |
| [9]  | DENIF   | <b>DMA Early Notification Interrupt</b><br>The DENIF high indicates the EMAC has received the LENGTH field of the incoming packet.<br>If the DENIF is high and DENIENI (EMAC_INTEN[9]) is enabled, the RXIF will be high. Write 1 to this bit clears the DENIF status.<br>0 = The LENGTH field of incoming packet has not received yet.<br>1 = The LENGTH field of incoming packet has received.                                                                                                                                                                |
| [8]  | MFLEIF  | <b>Maximum Frame Length Exceed Interrupt Flag</b><br>The MFLEIF high indicates the length of the incoming packet has exceeded the length limitation configured in DMARFC register and the incoming packet is dropped. If the MFLEIF is high and MFLEIEN (EMAC_INTEN[8]) is enabled, the RXIF will be high. Write 1 to this bit clears the MFLEIF status.<br>0 = The length of the incoming packet does not exceed the length limitation configured in DMARFC.<br>1 = The length of the incoming packet has exceeded the length limitation configured in DMARFC. |
| [7]  | MPCOVIF | <b>Missed Packet Counter Overrun Interrupt Flag</b><br>The MPCOVIF high indicates the MPCNT, Missed Packet Count, has overflow. If the MPCOVIF is high and MPCOVIEN (EMAC_INTEN[7]) is enabled, the RXIF will be high. Write 1 to this bit clears the MPCOVIF status.<br>0 = The MPCNT has not rolled over yet.<br>1 = The MPCNT has rolled over yet.                                                                                                                                                                                                           |
| [6]  | RPIF    | <b>Runt Packet Interrupt</b><br>The RPIF high indicates the length of the incoming packet is less than 64 bytes and the packet is dropped. If the ARP (EMAC_CTL[2]) is set, the short packet is regarded as a good packet and RPIF will not be set.<br>If the RPIF is high and RPIEN (EMAC_INTEN[6]) is enabled, the RXIF will be high. Write 1 to this bit clears the RPIF status.<br>0 = The incoming frame is not a short frame or S/W wants to receive a short frame.<br>1 = The incoming frame is a short frame and dropped.                               |
| [5]  | ALIEIF  | <b>Alignment Error Interrupt</b><br>The ALIEIF high indicates the length of the incoming frame is not a multiple of byte. If the ALIEIF is high and ALIEIEN (EMAC_INTEN[5]) is enabled, the RXIF will be high. Write 1 to this bit clears the ALIEIF status.<br>0 = The frame length is a multiple of byte.<br>1 = The frame length is not a multiple of byte.                                                                                                                                                                                                  |
| [4]  | RXGDIF  | <b>Receive Good Interrupt</b><br>The RXGDIF high indicates the frame reception has completed.<br>If the RXGDIEN (EAMC_MIEN[4]) is enabled, the RXIF will be high. Write 1 to this bit clears the RXGDIF status.<br>0 = The frame reception has not complete yet.<br>1 = The frame reception has completed.                                                                                                                                                                                                                                                      |

|     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3] | <b>LPIF</b>   | <b>Long Packet Interrupt Flag</b><br>The LPIF high indicates the length of the incoming packet is greater than 1518 bytes and the incoming packet is dropped. If the ALP (EMAC_CTL[1]) is set, the long packet will be regarded as a good packet and LPIF will not be set.<br>If the LPIF is high and LPIEN (EMAC_INTEN[3]) is enabled, the RXIF will be high. Write 1 to this bit clears the LPIF status.<br>0 = The incoming frame is not a long frame or S/W wants to receive a long frame.<br>1 = The incoming frame is a long frame and dropped.                                                                                                                                                                                                                                                                                                                                     |
| [2] | <b>RXOVIF</b> | <b>Receive FIFO Overflow Interrupt</b><br>The RXOVIF high indicates the RXFIFO overflow occurred during packet reception. While the RXFIFO overflow occurred, the EMAC drops the current receiving packet. If the RXFIFO overflow occurred often, it is recommended that modify RXFIFO threshold control, the RXFIFOTH of FFTCR register, to higher level.<br>If the RXOVIF is high and RXOVIEN (EMAC_INTEN[2]) is enabled, the RXIF will be high. Write 1 to this bit clears the RXOVIF status.<br>0 = No RXFIFO overflow occurred during packet reception.<br>1 = RXFIFO overflow occurred during packet reception.                                                                                                                                                                                                                                                                     |
| [1] | <b>CRCEIF</b> | <b>CRC Error Interrupt</b><br>The CRCEIF high indicates the incoming packet incurred the CRC error and the packet is dropped. If the AEP (EMAC_CTL[4]) is set, the CRC error packet will be regarded as a good packet and CRCEIF will not be set.<br>If the CRCEIF is high and CRCEIEN (EMAC_INTEN[1]) is enabled, the RXIF will be high. Write 1 to this bit clears the CRCEIF status.<br>0 = The frame does not incur CRC error.<br>1 = The frame incurred CRC error.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [0] | <b>RXIF</b>   | <b>Receive Interrupt</b><br>The RXIF indicates the RX interrupt status.<br>If RXIF high and its corresponding enable bit, RXIEN (EMAC_INTEN[0]), is also high indicates the EMAC generates RX interrupt to CPU. If RXIF is high but RXIEN (EMAC_INTEN[0]) is disabled, no RX interrupt is generated.<br>The RXIF is logic OR result of bit logic AND result of EMAC_INTSTS[15:1] and EMAC_INTEN[15:1]. In other words, if any bit of EMAC_INTSTS[15:1] is high and its corresponding enable bit in EMAC_INTEN[15:1] is also enabled, the RXIF will be high.<br>Because the RXIF is a logic OR result, clears EMAC_INTSTS[15:1] makes RXIF be cleared, too.<br>0 = No status bit in EMAC_INTSTS[15:1] is set or no enable bit in EMAC_INTEN[15:1] is enabled.<br>1 = At least one status in EMAC_INTSTS[15:1] is set and its corresponding enable bit in EMAC_INTEN[15:1] is enabled, too. |

**MAC General Status Register (EMAC\_GENSTS)**

The EMAC\_GENSTS also keeps the statuses of EMAC. But the statuses in the EMAC\_GENSTS will not trigger any interrupt. The EMAC\_GENSTS is a write clear register and write 1 to corresponding bit clears the status.

| Register    | Offset        | R/W | Description                 |  |  |  | Reset Value |
|-------------|---------------|-----|-----------------------------|--|--|--|-------------|
| EMAC_GENSTS | EMAC_BA+0x0B4 | R/W | MAC General 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 |    |    | RPSTS | TXHALT   | SQE     | TXPAUSED | DEF |
| 7        | 6  | 5  | 4     | 3        | 2       | 1        | 0   |
| COLCNT   |    |    |       | Reserved | RXFFULL | RXHALT   | CFR |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [12]    | RPSTS       | <b>Remote Pause Status</b><br>The RPSTS indicates that remote pause counter down counting actives.<br>After Ethernet MAC controller sent PAUSE frame out successfully, it starts the remote pause counter down counting. When this bit high, it's predictable that remote Ethernet MAC controller wouldn't start the packet transmission until the down counting done.<br>0 = Remote pause counter down counting done.<br>1 = Remote pause counter down counting actives. |
| [11]    | TXHALT      | <b>Transmission Halted</b><br>The TXHALT high indicates the next normal packet transmission process will be halted because the bit TXON (EMAC_CTL[8]) is disabled by S/W.<br>0 = Next normal packet transmission process will go on.<br>1 = Next normal packet transmission process will be halted.                                                                                                                                                                       |
| [10]    | SQE         | <b>Signal Quality Error</b><br>The SQE high indicates the SQE error found at end of packet transmission on 10Mbps half-duplex mode. The SQE error check will only be done while both bit SQECHKEN (EMAC_CTL[17]) is enabled and EMAC is operating on 10Mbps half-duplex mode.<br>0 = No SQE error found at end of packet transmission.<br>1 = SQE error found at end of packet transmission.                                                                              |
| [9]     | TXPAUSED    | <b>Transmission Paused</b><br>The TXPAUSED high indicates the next normal packet transmission process will be paused temporally because EMAC received a PAUSE control frame.<br>0 = Next normal packet transmission process will go on.<br>1 = Next normal packet transmission process will be paused.                                                                                                                                                                    |

|       |                 |                                                                                                                                                                                                                                                                                  |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8]   | <b>DEF</b>      | <b>Deferred Transmission</b><br>The DEF high indicates the packet transmission has deferred once. The DEF is only available while EMAC is operating on half-duplex mode.<br>0 = Packet transmission does not defer.<br>1 = Packet transmission has deferred once.                |
| [7:4] | <b>COLCNT</b>   | <b>Collision Count</b><br>The COLCNT indicates that how many collisions occurred consecutively during a packet transmission. If the packet incurred 16 consecutive collisions during transmission, the COLCNT will be 4'h0 and bit TXABTIF will be set to 1.                     |
| [3]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                        |
| [2]   | <b>RXFFULL</b>  | <b>RXFIFO Full</b><br>The RXFFULL indicates the RXFIFO is full due to four 64-byte packets are kept in RXFIFO and the following incoming packet will be dropped.<br>0 = The RXFIFO is not full.<br>1 = The RXFIFO is full and the following incoming packet will be dropped.     |
| [1]   | <b>RXHALT</b>   | <b>Receive Halted</b><br>The RXHALT high indicates the next normal packet reception process will be halted because the bit RXON of MCMDR is disabled by S/W.<br>0 = Next normal packet reception process will go on.<br>1 = Next normal packet reception process will be halted. |
| [0]   | <b>CFR</b>      | <b>Control Frame Received</b><br>The CFRIF high indicates EMAC receives a flow control frame. The CFRIF only available while EMAC is operating on full duplex mode.<br>0 = The EMAC does not receive the flow control frame.<br>1 = The EMAC receives a flow control frame.      |

**Missed Packet Count Register (EMAC\_MPCNT)**

The EMAC\_MPCNT keeps the number of packets that were dropped due to various types of receive errors. The EMAC\_MPCNT is a read clear register. In addition, S/W also can write an initial value to EMAC\_MPCNT and the missed packet counter will start counting from that initial value. If the missed packet counter is overflow, the MPCOVIF (EMAC\_INTSTS[7]) will be set.

| Register   | Offset        | R/W | Description                  |  |  |  | Reset Value |
|------------|---------------|-----|------------------------------|--|--|--|-------------|
| EMAC_MPCNT | EMAC_BA+0x0B8 | R/W | Missed Packet Count Register |  |  |  | 0x0000_7FFF |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [15:0]  | MPCNT       | <b>Miss Packet Count</b><br>The MPCNT indicates the number of packets that were dropped due to various types of receive errors. The following type of receiving error makes missed packet counter increase: <ol style="list-style-type: none"> <li>1. Incoming packet is incurred RXFIFO overflow.</li> <li>2. Incoming packet is dropped due to RXON is disabled.</li> <li>3. Incoming packet is incurred CRC error.</li> </ol> |

**MAC Receive Pause Count Register (EMAC\_RPCNT)**

The EMAC supports the PAUSE control frame reception and recognition. If EMAC received a PAUSE control frame, the OPERAND field of the PAUSE control frame will be extracted and stored in the EMAC\_RPCNT register. The EMAC\_RPCNT register will keep the same while TX of EMAC is pausing due to the PAUSE control frame is received. The EMAC\_RPCNT is read only and write to this register has no effect.

| Register   | Offset        | R/W | Description                      |  |  |  |  | Reset Value |
|------------|---------------|-----|----------------------------------|--|--|--|--|-------------|
| EMAC_RPCNT | EMAC_BA+0x0BC | R   | MAC Receive Pause Count Register |  |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                               |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                     |
| [15:0]  | RPCNT       | <b>MAC Receive Pause Count</b><br>The RPCNT keeps the OPERAND field of the PAUSE control frame. It indicates how many slot time (512-bit time) the TX of EMAC will be paused. |

**DMA Receive Frame Status Register (EMAC\_FRSTS)**

The EMAC\_FRSTS is used to keep the LENGTH field of each incoming Ethernet packet.

| Register   | Offset        | R/W | Description                       |  |  |  | Reset Value |
|------------|---------------|-----|-----------------------------------|--|--|--|-------------|
| EMAC_FRSTS | EMAC_BA+0x0C8 | R/W | DMA Receive Frame Status Register |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                        |
| [15:0]  | RXFLT       | <b>Receive Frame LENGTH</b><br>The RXFLT keeps the LENGTH field of each incoming Ethernet packet. If the bit DENIEN (EMAC_INTEN[9]) is enabled and the LENGTH field of incoming packet has received, the bit DENIF (EMAC_INTSTS[9]) will be set and trigger interrupt. And, the content of LENGTH field will be stored in RXFLT. |

Current Transmit Descriptor Start Address Register (EMAC\_CTXDSA)

| Register    | Offset        | R/W | Description                                        |  |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------------------------------|--|--|--|--|-------------|
| EMAC_CTXDSA | EMAC_BA+0x0CC | R   | Current Transmit Descriptor Start Address Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                               |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CTXDSA      | <b>Current Transmit Descriptor Start Address</b><br>The CTXDSA keeps the start address of TX descriptor that is used by TXDMA currently.<br>The CTXDSA is read only and write to this register has no effect. |

Current Transmit Buffer Start Address Register (EMAC\_CTXBSA)

| Register    | Offset        | R/W | Description                                    |  |  |  |  | Reset Value |
|-------------|---------------|-----|------------------------------------------------|--|--|--|--|-------------|
| EMAC_CTXBSA | EMAC_BA+0x0D0 | R   | Current Transmit Buffer Start Address Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                          |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CTXBSA      | <b>Current Transmit Buffer Start Address</b><br>The CTXDSA keeps the start address of TX frame buffer that is used by TXDMA currently. The CTXBSA is read only and write to this register has no effect. |

Current Receive Descriptor Start Address Register (EMAC\_CRXDSA)

| Register    | Offset        | R/W | Description                                       |  |  |  |  | Reset Value |
|-------------|---------------|-----|---------------------------------------------------|--|--|--|--|-------------|
| EMAC_CRXDSA | EMAC_BA+0x0D4 | R   | Current Receive Descriptor Start Address Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                          |                                                                                                                                                        |
|--------|-------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CRXDSA      | Current Receive Descriptor Start Address | The CRXDSA keeps the start address of RX descriptor that is used by RXDMA currently. The CRXDSA is read only and write to this register has no effect. |

Current Receive Buffer Start Address Register (EMAC\_CRXBSA)

| Register    | Offset        | R/W | Description                                   |  |  |  |  | Reset Value |
|-------------|---------------|-----|-----------------------------------------------|--|--|--|--|-------------|
| EMAC_CRXBSA | EMAC_BA+0x0D8 | R   | Current Receive Buffer Start Address Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                         |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CRXBSA      | <b>Current Receive Buffer Start Address</b><br>The CRXBSA keeps the start address of RX frame buffer that is used by RXDMA currently. The CRXBSA is read only and write to this register has no effect. |

**Time Stamp Control Register (EMAC\_TSCTL)**

| Register   | Offset        | R/W | Description                 | Reset Value |
|------------|---------------|-----|-----------------------------|-------------|
| EMAC_TSCTL | EMAC_BA+0x100 | R/W | Time Stamp 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 |    | TSALMEN | Reserved | TSUPDATE | TSMODE | TSIEN | TSEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [5]    | TSALMEN     | <p><b>Time Stamp Alarm Enable Bit</b></p> <p>Set this bit high enable Ethernet MAC controller to set TSALMIF (EMAC_INTSTS[28]) high when EMAC_TSSEC equals to EMAC_ALMSEC and EMAC_TSSUBSEC equals to EMAC_ALMSUBSEC.</p> <p>0 = Alarm disabled when EMAC_TSSEC equals to EMAC_ALMSEC and EMAC_TSSUBSEC equals to EMAC_ALMSUBSEC.</p> <p>1 = Alarm enabled when EMAC_TSSEC equals to EMAC_ALMSEC and EMAC_TSSUBSEC equals to EMAC_ALMSUBSEC.</p> |
| [4]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [3]    | TSUPDATE    | <p><b>Time Stamp Counter Time Update Enable Bit</b></p> <p>Set this bit high enables Ethernet MAC controller to add value of register EMAC_UPDSEC and EMAC_UPDSUBSEC to PTP time stamp counter.</p> <p>After the add operation finished, Ethernet MAC controller clear this bit to low automatically.</p> <p>0 = No action.</p> <p>1 = EMAC_UPDSEC updated to EMAC_TSSEC and EMAC_UPDSUBSEC updated to EMAC_TSSUBSEC.</p>                        |
| [2]    | TSMODE      | <p><b>Time Stamp Fine Update Enable Bit</b></p> <p>This bit chooses the time stamp counter update mode.</p> <p>0 = Time stamp counter is in coarse update mode.</p> <p>1 = Time stamp counter is in fine update mode.</p>                                                                                                                                                                                                                        |
| [1]    | TSIEN       | <p><b>Time Stamp Counter Initialization Enable Bit</b></p> <p>Set this bit high enables Ethernet MAC controller to load value of register EMAC_UPDSEC and EMAC_UPDSUBSEC to PTP time stamp counter.</p> <p>After the load operation finished, Ethernet MAC controller clear this bit to low automatically.</p> <p>0 = Time stamp counter initialization done.</p> <p>1 = Time stamp counter initialization Enabled.</p>                          |

|     |      |                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | TSEN | <b>Time Stamp Function Enable Bit</b><br>This bit controls if the IEEE 1588 PTP time stamp function is enabled or not.<br>Set this bit high to enable IEEE 1588 PTP time stamp function while set this bit low to disable IEEE 1588 PTP time stamp function.<br>0 = IEEE 1588 PTP time stamp function Disabled.<br>1 = IEEE 1588 PTP time stamp function Enabled. |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**Time Stamp Counter Second Register (EMAC\_TSSEC)**

| Register   | Offset        | R/W | Description                        |  |  |  |  | Reset Value |
|------------|---------------|-----|------------------------------------|--|--|--|--|-------------|
| EMAC_TSSEC | EMAC_BA+0x110 | R   | Time Stamp Counter Second Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                    |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SEC         | <b>Time Stamp Counter Second</b><br>This register reflects the bit [63:32] value of 64-bit reference timing counter. This 32-bit value is used as the second part of time stamp when TSEN (EMAC_TSCTL[0]) is high. |

Time Stamp Counter Sub Second Register (EMAC\_TSSUBSEC)

| Register      | Offset        | R/W | Description                            | Reset Value |
|---------------|---------------|-----|----------------------------------------|-------------|
| EMAC_TSSUBSEC | EMAC_BA+0x114 | R   | Time Stamp Counter Sub Second Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SUBSEC      | <b>Time Stamp Counter Sub-second</b><br>This register reflects the bit [31:0] value of 64-bit reference timing counter. This 32-bit value is used as the sub-second part of time stamp when TSEN (EMAC_TSCTL[0]) is high. |

**Time Stamp Increment Register (EMAC\_TSINC)**

| Register   | Offset        | R/W | Description                   |  |  |  | Reset Value |
|------------|---------------|-----|-------------------------------|--|--|--|-------------|
| EMAC_TSINC | EMAC_BA+0x118 | R/W | Time Stamp Increment 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  |
| CNTINC   |    |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                  |
| [7:0]  | CNTINC      | <b>Time Stamp Counter Increment</b><br>Time stamp counter increment value.<br>If TSEN (EMAC_TSCTL[0]) is high, EMAC adds EMAC_TSSUBSEC with this 8-bit value every time when it wants to increase the EMAC_TSSUBSEC value. |

**Time Stamp Addend Register (EMAC\_TSADDEND)**

| Register      | Offset        | R/W | Description                | Reset Value |
|---------------|---------------|-----|----------------------------|-------------|
| EMAC_TSADDEND | EMAC_BA+0x11C | R/W | Time Stamp Addend Register | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | ADDEND      | <p><b>Time Stamp Counter Addend</b></p> <p>This register keeps a 32-bit value for accumulator to enable increment of EMAC_TSSUBSEC.</p> <p>If TSEN (EMAC_TSCTL[0]) and TSMODE (EMAC_TSCTL[2]) are both high, the EMAC increases accumulator with this 32-bit value in each HCLK. Once the accumulator is overflow, it generates a enable to increase EMAC_TSSUBSEC with an 8-bit value kept in register EMAC_TSINC.</p> |

Time Stamp Update Second Register (EMAC\_UPDSEC)

| Register    | Offset        | R/W | Description                       |  |  |  |  | Reset Value |
|-------------|---------------|-----|-----------------------------------|--|--|--|--|-------------|
| EMAC_UPDSEC | EMAC_BA+0x120 | R/W | Time Stamp Update Second Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SEC         | <b>Time Stamp Counter Second Update</b><br>When TSIEN (EMAC_TSCTL[1]) is high, EMAC loads this 32-bit value to EMAC_TSSEC directly. When TSUPDATE (EMAC_TSCTL[3]) is high, the EMAC increases EMAC_TSSEC with this 32-bit value. |

Time Stamp Update Sub Second Register (EMAC\_UPDSUBSEC)

| Register       | Offset        | R/W | Description                           | Reset Value |
|----------------|---------------|-----|---------------------------------------|-------------|
| EMAC_UPDSUBSEC | EMAC_BA+0x124 | R/W | Time Stamp Update Sub Second Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SUBSEC      | <b>Time Stamp Counter Sub-second Update</b><br>When TSIEN (EMAC_TSCTL[1]) is high, EMAC loads this 32-bit value to EMAC_TSSUBSEC directly. When TSUPDATE (EMAC_TSCTL[3]) is high, the EMAC increases EMAC_TSSUBSEC with this 32-bit value. |

**Time Stamp Alarm Second Register (EMAC\_ALMSEC)**

| Register    | Offset        | R/W | Description                      |  |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------------|--|--|--|--|-------------|
| EMAC_ALMSEC | EMAC_BA+0x128 | R/W | Time Stamp Alarm Second Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SEC         | <p><b>Time Stamp Counter Second Alarm</b><br/> Time stamp counter second part alarm value.<br/> This value is only useful when ALMEN (EMAC_TSCTL[5]) is high. If ALMEN (EMAC_TSCTL[5]) is high, EMAC_TSSEC equals to EMAC_ALMSEC and EMAC_TSSUBSEC equals to EMAC_ALMSUBSEC, the Ethernet MAC controller sets TSALMIF (EMAC_INTSTS[28]) high.</p> |

Time Stamp Alarm Sub Second Register (EMAC\_ALMSUBSEC)

| Register       | Offset        | R/W | Description                          | Reset Value |
|----------------|---------------|-----|--------------------------------------|-------------|
| EMAC_ALMSUBSEC | EMAC_BA+0x12C | R/W | Time Stamp Alarm Sub Second Register | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SUBSEC      | <p><b>Time Stamp Counter Sub-second Alarm</b><br/>Time stamp counter sub-second part alarm value.</p> <p>This value is only useful when ALMEN (EMAC_TSCTL[5]) is high. If ALMEN (EMAC_TSCTL[5]) is high, EMAC_TSSEC equals to EMAC_ALMSEC and EMAC_TSSUBSEC equals to EMAC_ALMSUBSEC, the Ethernet MAC controller sets TSALMIF (EMAC_INTSTS[28]) high.</p> |

## 6.17 Smart Card Host Interface (SC)

### 6.17.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.17.2 Features

- ISO 7816-3 T = 0, T = 1 compliant
- EMV2000 compliant
- Three ISO 7816-3 ports
- Separates receive/transmit 4 byte entry FIFO for data payloads
- Programmable transmission clock frequency
- Programmable receiver buffer trigger level
- Programmable guard time selection (11 ETU ~ 267 ETU)
- One 24-bit timer and two 8-bit timers for Answer to Request (ATR) and waiting times processing
- Supports auto direct / inverse convention function
- Supports transmitter and receiver error retry and error number limiting function
- Supports hardware activation sequence process, and the 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 TX-FIFO 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.17.3 Block Diagram

The SC clock control and block diagram are shown in SC Clock Control Diagram (7-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 engine clock.



Figure 6.17-1 SC Clock Control Diagram (7-bit Pre-scale Counter in Clock Controller)



Figure 6.17-2 SC Controller Block Diagram

#### 6.17.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.17-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.17-2 UART Pin Description

##### 6.17.4.1 SC0 Basic Configuration

- Clock Source Configuration
  - Select the source of SC0 peripheral clock on SC0SEL (CLK\_CLKSEL3[1:0]).
  - Select the clock divider number of SC0 peripheral clock on SC0DIV(CLK\_CLKDIV1[7:0]).
  - Enable SC0 peripheral clock in SC0CKEN (CLK\_APBCLK1[0]).
- Reset Configuration
  - Reset SC0 controller in SC0RST (SYS\_IPRST2[0]).
- Pin Configuration

| Group | Pin Name | GPIO | MFP  |
|-------|----------|------|------|
| SC0   | SC0_CLK  | PB.5 | MFP9 |
|       |          | PF.6 | MFP3 |
|       |          | PA.0 | MFP6 |
|       |          | PE.2 | MFP6 |
|       | SC0_DAT  | PB.4 | MFP9 |
|       |          | PF.7 | MFP3 |
|       |          | PA.1 | MFP6 |
|       |          | PE.3 | MFP6 |
|       | SC0_PWR  | PB.2 | MFP9 |
|       |          | PF.9 | MFP3 |
|       |          | PA.3 | MFP6 |

|         |  |       |      |
|---------|--|-------|------|
|         |  | PE.5  | MFP6 |
| SC0_RST |  | PB.3  | MFP9 |
|         |  | PF.8  | MFP3 |
|         |  | PA.2  | MFP6 |
|         |  | PE.4  | MFP6 |
| SC0_nCD |  | PC.12 | MFP9 |
|         |  | PF.10 | MFP3 |
|         |  | PA.4  | MFP6 |
|         |  | PE.6  | MFP6 |

#### 6.17.4.2 SC1 Basic Configuration

- Clock Source Configuration
  - Select the source of SC1 peripheral clock on SC1SEL (CLK\_CLKSEL3[3:2]).
  - Select the clock divider number of SC1 peripheral clock on SC1DIV(CLK\_CLKDIV1[15:8]).
  - Enable SC1 peripheral clock in SC1CKEN (CLK\_APBCLK1[1]).
- Reset Configuration
  - Reset SC1 controller in SC1RST (SYS\_IPRST2[1]).
- Pin Configuration

| Group | Pin Name | GPIO  | MFP  |
|-------|----------|-------|------|
| SC1   | SC1_CLK  | PC.0  | MFP5 |
|       |          | PD.4  | MFP8 |
|       |          | PG.8  | MFP4 |
|       |          | PB.12 | MFP3 |
|       | SC1_DAT  | PC.1  | MFP5 |
|       |          | PD.5  | MFP8 |
|       |          | PG.7  | MFP4 |
|       |          | PB.13 | MFP3 |
|       | SC1_PWR  | PC.3  | MFP5 |
|       |          | PD.7  | MFP8 |
|       |          | PG.5  | MFP4 |
|       |          | PB.15 | MFP3 |
|       | SC1_RST  | PC.2  | MFP5 |
|       |          | PD.6  | MFP8 |
|       |          | PG.6  | MFP4 |
|       |          | PB.14 | MFP3 |
|       | SC1_nCD  | PC.4  | MFP5 |

|  |  |       |      |
|--|--|-------|------|
|  |  | PD.3  | MFP8 |
|  |  | PD.14 | MFP4 |
|  |  | PC.14 | MFP3 |

#### 6.17.4.3 SC2 Basic Configuration

- Clock Source Configuration
  - Select the source of SC2 peripheral clock on SC2SEL (CLK\_CLKSEL3[5:4]).
  - Select the clock divider number of SC2 peripheral clock on SC2DIV(CLK\_CLKDIV1[23:16]).
  - Enable SC2 peripheral clock in SC2CKEN (CLK\_APBCLK1[2]).
- Reset Configuration
  - Reset SC2 controller in SC2RST (SYS\_IPRST2[2]).
- Pin Configuration

| Group | Pin Name | GPIO  | MFP  |
|-------|----------|-------|------|
| SC2   | SC2_CLK  | PA.8  | MFP3 |
|       |          | PA.6  | MFP6 |
|       |          | PD.0  | MFP7 |
|       |          | PA.15 | MFP7 |
|       |          | PE.0  | MFP4 |
|       | SC2_DAT  | PA.9  | MFP3 |
|       |          | PA.7  | MFP6 |
|       |          | PD.1  | MFP7 |
|       |          | PA.14 | MFP7 |
|       |          | PE.1  | MFP4 |
|       | SC2_PWR  | PA.11 | MFP3 |
|       |          | PC.7  | MFP6 |
|       |          | PD.3  | MFP7 |
|       |          | PA.12 | MFP7 |
|       |          | PH.8  | MFP4 |
|       | SC2_RST  | PA.10 | MFP3 |
|       |          | PC.6  | MFP6 |
|       |          | PD.2  | MFP7 |
|       |          | PA.13 | MFP7 |
|       |          | PH.9  | MFP4 |
|       | SC2_nCD  | PC.13 | MFP3 |
|       |          | PA.5  | MFP6 |
|       |          | PD.13 | MFP7 |

|  |  |       |      |
|--|--|-------|------|
|  |  | PH.10 | MFP4 |
|--|--|-------|------|

### 6.17.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.17-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.17.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(SC\_CDPINSTS[13]). SCn\_CD related function can be set by CDLV(SC\_CTL[26]), CDDBSEL(SC\_CTL[25:24]), CDIF(SC\_INTSTS[7]), CDIEN(SC\_INTEN[7]).
6. CDLV(SC\_CTL[26]) determines what kind of pin level change represents the card insertion. CDDBSEL(SC\_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 remmoned setting before enable SC.

#### 6.17.5.2 Activation, Warm Reset and Deactivation Sequence

##### Activation

The activation sequence is shown in Figure 6.17-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 CNT (SCn\_TMRCTL0[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 TMR0IF (SCn\_INTSTS[3]).



Figure 6.17-4 SC Activation Sequence

### Warm Reset

The warm reset sequence is shown in Figure 6.17-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\_DATA pin state can be programmed by SCn\_PINCTL. The warm reset sequence timing can be controlled by setting SCn\_TMRCTLx ( $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\_TMRCTL0[27:24]) to 0011 and give an Answer to

Request (ATR) value by setting CNT (SCn\_TMRCTL0[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 TMR0IF (SCn\_INTSTS[3]).



Figure 6.17-5 SC Warm Reset Sequence

### Deactivation

The deactivation sequence is shown in Figure 6.17-6.

1. Set SCn\_RST to low by programming RSTEN (SCn\_PINCTL[1]) to '0', wait SYNC(SCn\_PINCTL[31]) is cleared to 0.
  1. Stop SCn\_CLK by programming CLKKEEP (SCn\_PINCTL[6]) to '0', wait SYNC(SCn\_PINCTL[31]) is cleared to 0.
  2. Set SCn\_DATA to low by programming SCDATA (SCn\_PINCTL[9]) to '0', wait SYNC(SCn\_PINCTL[31]) is cleared to 0.
  3. 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\_TMRCTL0 to process the deactivation sequence. SCn\_PWR, SCn\_CLK, SC.n\_RST and SCn\_DATA pin state can be programmed by SCn\_PINCTL. The deactivation sequence timing can be controlled by setting SCn\_TMRCTL0. 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]).



Figure 6.17-6 SC Deactivation Sequence

#### 6.17.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.17-7 Basic Operation Flow

#### 6.17.5.4 Initial Character TS

According to ISO 7816-3, the initial character TS has two possible patterns shown in Figure 6.17-8. If the TS pattern is 1100\_0000, it is inverse convention. When decoded by inverse convention, the conveyed byte is equal to 0x3F. If the TS pattern is 1101\_1100, it is direct convention. When decoded by direct convention, the conveyed byte is equal to 0x3B. User can set AUTOSEN (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 AUTOSEN (SCn\_CTL[3]) register, the setting step must be done before Answer to Request (ATR) state and the received first data must be 0x3B or 0x3F. After hardware received first data and stored it at SCn\_DAT, the hardware will decide the convention and change the CONSEL (SCn\_CTL[5:4]) register automatically. If the received first data is neither 0x3B nor 0x3F, 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.17-8 Initial Character TS

#### 6.17.5.5 Transfer Data Flow and Data Buffer Status

After setting initial sequence, SC can start transferring data which format is corresponding to ISO 7816-3. Set ETURDIV(SC\_ETUCTL[11:0]) to 273 to make ETU(Element Timing Unit) meet ISO 7816-3. Writing data to SC\_DAT, SC will send out an 8-bit data to smart card. Reading data from SC\_DAT, SC will return an 8-bit received data from smart card.

Data buffer status show in SC\_STATUS. TXPOINT(SC\_STATUS[26:24]) and RXPOINT(SC\_STATUS[18:16]) represent how many data in transmit buffer and received buffer. TXEMPTY(SC\_STATUS[9]), TXFULL(SC\_STATUS[10]), TXOV(SC\_STATUS[8]), RXEMPTY(SC\_STATUS[1]), RXFULL(SC\_STATUS[2]), RXOV(SC\_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]) flag. After interrupt is generated, it can be clear by writing 1 to TBEIF(SCn\_INTSTS[1]). SC can decide to transfer data or not by polling these status.

TX and RX can be disabled separately by setting TXOFF(SC\_CTL[2]) and RXOFF(SC\_CTL[1]). TXACT(SC\_STATUS[31]) and RXACT(SC\_STATUS[23]) represent the TX transfer/RX transfer is active or not.

#### 6.17.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.17.5.7 Error Signal and Character Repetition

According to ISO 7816-3 T=0 mode description, as shown in Figure 6.17-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.17-9 SC Error Signal

#### 6.17.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\_TMRCTL0[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 TMR0IEN(SCn\_INTEN[3]), TMR1IEN(SCn\_INTEN[4]), TMR2IEN(SCn\_INTEN[5]) are enable, SC will generate a interrupt to CPU.

The SCn\_TMRCTL0, SCn\_TMRCTL1 and SCn\_TMRCTL2 timer operation mode are listed in Table 6.17-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]), 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_TMRCTL0[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 TMR0IF, 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_TMRCTL0[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 TMR0IF, 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 time-out 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 TMR0IF, 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><br>The timing starts when SCn_RST de-assertion and ends when ATR response received or time-out.<br><br>If the counter decreases to 0 before ATR response received, hardware will set TMR0IF (SCn_INTSTS[3]) and generate an interrupt to CPU if TMR0IEN (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 CNTEN0 (SCn_ALTCTL[5]) set to 1.<br>It is only used for hardware activation, warm reset mode.                                                                                                                                                                                                                                                                                                  |
|                                              | End                                                                                                                                                                                                                                                                                                                                                                                                                                          | When the down counter equals 0 before ATR response received, hardware will set TMR0IF and clear CNTEN0 (SCn_ALTCTL[5]) automatically.<br><br>When ATR received and down counter does not equal to 0, hardware will clear CNTEN0 (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 (SCn_TMRCTL0[23:0], SCn_TMRCTL0[7:0], SCn_TMRCTL0[7:0]) value at any time. It will reload the last value which is filled into the CNT(SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) before the counter count to 0.<br><br>Only when the down counter equals 0, counter reload the CNT (SCn_TMRCTL0[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 TMR0IF, 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 use clears CNTENx (SCn_ALTCTL[7:5]) bit.                                                                                                                                                                                                                                                                                                                                                                        |

|      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | Start           | The down counter is started when the first START bit (reception or transmission) detected after CNTEXn (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.                                                                                                                                                                                              |
| 0101 | Reload          | When ACTSTSx (SCn_ALTCTL[15:13]) is 1, user can change CNT (SCn_TMRCTL0[23:0], SCn_TMRCTL0[7:0], SCn_TMRCTL0[7:0]) value at any time. It will reload the last value which is filled into the CNT(SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) before the counter count to 0. Only when the down counter equals 0, counter will reload the CNT (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 TMR0IF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and generate an interrupt to CPU if TMRxEN (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 CNTEXn (SCn_ALTCTL[7:5]) bit.                                                                                                                                                                                                                                                                                                                                                |
|      | Start           | The down counter is started when the first START bit (reception) detected after CNTEXn (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.                                                                                                                                                                                                              |
| 0110 | Reload          | When ACTSTSx (SCn_ALTCTL[15:13]) is 1, user can change CNT (SCn_TMRCTL0[23:0], SCn_TMRCTL0[7:0], SCn_TMRCTL0[7:0]) value at any time. It will reload the last value which is filled into the CNT(SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) before the counter counts to 0. Only when the down counter equals 0, counter reload the CNT (SCn_TMRCTL0[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 TMR0IF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and generate an interrupt to CPU if TMRxEN (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 CNTEXn (SCn_ALTCTL[7:5]) bit.                                                                                                                                                                                                                                                                                                                                                |
|      | Start           | The down counter is started when the first START bit (reception or transmission) detected after CNTEXn (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.                                                                                                                                                                                              |
| 0111 | 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 TMR0IF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and generate an interrupt to CPU if TMRxEN (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 CNTEXn (SCn_ALTCTL[7:5]) bit.                                                                                                                                                                                                                                                                                                                                                |
|      | Start           | The down counter starts counting when user sets CNTEXn (SCn_ALTCTL[7:5]) bit and it will count to time-out.                                                                                                                                                                                                                                                                                                            |
| 1111 | 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_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. |

Table 6.17-3 Timer0/Timer1/Timer2 Operation Mode

#### 6.17.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 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.17-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.17-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.17-12Figure 6.17-11.



Figure 6.17-12 Extra Guard Time Operation

#### 6.17.5.10 UART Mode

When the UARLEN (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 AUTOSEN (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\_RXTOOUT[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.17.6 Register Map

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

| Register                                   | Offset      | R/W | Description                                 | Reset Value |
|--------------------------------------------|-------------|-----|---------------------------------------------|-------------|
| <b>SC Base Address:</b>                    |             |     |                                             |             |
| <b>SCn_BA = 0x4009_0000 + (0x1000 * n)</b> |             |     |                                             |             |
| n=0,1,2                                    |             |     |                                             |             |
| <b>SC_DAT</b>                              | SCn_BA+0x00 | R/W | SC Receive/Transmit Holding Buffer Register | 0xFFFF_FFFF |
| <b>SC_CTL</b>                              | SCn_BA+0x04 | R/W | SC Control Register                         | 0x0000_0000 |
| <b>SC_ALTCTL</b>                           | SCn_BA+0x08 | R/W | SC Alternate Control Register               | 0x0000_0000 |
| <b>SC_EGT</b>                              | SCn_BA+0x0C | R/W | SC Extra Guard Time Register                | 0x0000_0000 |
| <b>SC_RXTOUT</b>                           | SCn_BA+0x10 | R/W | SC Receive Buffer Time-out Counter Register | 0x0000_0000 |
| <b>SC_ETUCTL</b>                           | SCn_BA+0x14 | R/W | SC Element Time Unit Control Register       | 0x0000_0173 |
| <b>SC_INTEN</b>                            | SCn_BA+0x18 | R/W | SC Interrupt Enable Control Register        | 0x0000_0000 |
| <b>SC_INTSTS</b>                           | SCn_BA+0x1C | R/W | SC Interrupt Status Register                | 0x0000_0002 |
| <b>SC_STATUS</b>                           | SCn_BA+0x20 | R/W | SC Transfer Status Register                 | 0x0000_X202 |
| <b>SC_PINCTL</b>                           | SCn_BA+0x24 | R/W | SC Pin Control State Register               | 0x0000_0000 |
| <b>SC_TMRCTL0</b>                          | SCn_BA+0x28 | R/W | SC Internal Timer0 Control Register         | 0x0000_0000 |
| <b>SC_TMRCTL1</b>                          | SCn_BA+0x2C | R/W | SC Internal Timer1 Control Register         | 0x0000_0000 |
| <b>SC_TMRCTL2</b>                          | SCn_BA+0x30 | R/W | SC Internal Timer2 Control Register         | 0x0000_0000 |
| <b>SC_UARTCTL</b>                          | SCn_BA+0x34 | R/W | SC UART Mode Control Register               | 0x0000_0000 |
| <b>SC_ACTCTL</b>                           | SCn_BA+0x4C | R/W | SC Activation Control Register              | 0x0000_0000 |

### 6.17.7 Register Description

#### SC Receive/Transmit Holding Buffer Register (SC\_DAT)

| Register | Offset      | R/W | Description                                 |  |  |  |  | Reset Value |
|----------|-------------|-----|---------------------------------------------|--|--|--|--|-------------|
| SC_DAT   | SCn_BA+0x00 | R/W | SC Receive/Transmit Holding Buffer Register |  |  |  |  | 0xFFFF_FFFF |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                      |
| [7:0]  | DAT         | <p><b>Receive/Transmit Holding Buffer</b></p> <p>Write Operation:<br/>By writing data to DAT, the SC will send out an 8-bit data.</p> <p><b>Note:</b> If SCEN (SCn_CTL[0]) is not enabled, DAT cannot be programmed.</p> <p>Read Operation:<br/>By reading DAT, the SC will return an 8-bit received data.</p> |

**SC Control Register (SC\_CTL)**

| Register | Offset      | R/W | Description         |  |  |  | Reset Value |
|----------|-------------|-----|---------------------|--|--|--|-------------|
| SC_CTL   | SCn_BA+0x04 | R/W | SC Control Register |  |  |  | 0x0000_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        | <p><b>SYNC Flag Indicator (Read Only)</b></p> <p>Due to synchronization, user should check this bit before writing a new value to RXRTY and TXRTY fields.</p> <p>0 = Synchronizing is completion, user can write new data to RXRTY and TXRTY.</p> <p>1 = Last value is synchronizing.</p>                                                                                                                         |
| [29:27] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                         |
| [26]    | CDLV        | <p><b>Card Detect Level Selection</b></p> <p>0 = When hardware detects the card detect pin (SCn_CD) from high to low, it indicates a card is detected.</p> <p>1 = When hardware detects the card detect pin (SCn_CD) from low to high, it indicates a card is detected.</p> <p><b>Note:</b> User must select card detect level before Smart Card controller enabled.</p>                                          |
| [25:24] | CDDBSEL     | <p><b>Card Detect De-bounce Selection</b></p> <p>This field indicates the card detect de-bounce selection.</p> <p>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.</p> <p>Other configurations are reserved.</p>                                                                                                        |
| [23]    | TXRTYEN     | <p><b>TX Error Retry Enable Bit</b></p> <p>This bit enables transmitter retry function when parity error has occurred.</p> <p>0 = TX error retry function Disabled.</p> <p>1 = TX error retry function Enabled.</p>                                                                                                                                                                                               |
| [22:20] | TXRTY       | <p><b>TX Error Retry Count Number</b></p> <p>This field indicates the maximum number of transmitter retries that are allowed when parity error has occurred.</p> <p><b>Note1:</b> The real retry number is TXRTY + 1, so 8 is the maximum retry number.</p> <p><b>Note2:</b> This field cannot be changed when TXRTYEN enabled. The change flow is to disable TXRTYEN first and then fill in new retry value.</p> |

|         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19]    | <b>RXRTYEN</b> | <b>RX Error Retry Enable Bit</b><br>This bit enables receiver retry function when parity error has occurred.<br>0 = RX error retry function Disabled.<br>1 = RX error retry function Enabled.<br><b>Note:</b> User must fill in the RXRTY value before enabling this bit.                                                                                                                                                                                                                 |
| [18:16] | <b>RXRTY</b>   | <b>RX Error Retry Count Number</b><br>This field indicates the maximum number of receiver retries that are allowed when parity error has occurred<br><b>Note1:</b> The real retry number is RXRTY + 1, so 8 is the maximum retry number.<br><b>Note2:</b> This field cannot be changed when RXRTYEN enabled. The change flow is to disable RXRTYEN first and then fill in new retry value.                                                                                                |
| [15]    | <b>NSB</b>     | <b>Stop Bit Length</b><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><b>Note1:</b> The default stop bit length is 2. SC and UART adopts NSB to program the stop bit length.<br><b>Note2:</b> In UART mode, RX can receive the data sequence in 1 stop bit or 2 stop bits with NSB is set to 0.                                                                                                             |
| [14:13] | <b>TMRSEL</b>  | <b>Timer Channel Selection</b><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]  | <b>BGT</b>     | <b>Block Guard Time (BGT)</b><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 T = 1 mode, user must fill 21 (real block guard time = 22.5) to it.<br><b>Note:</b> The real block guard time is BGT + 1. |
| [7:6]   | <b>RXTRGLV</b> | <b>Rx Buffer Trigger Level</b><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]   | <b>CONSEL</b>  | <b>Convention Selection</b><br>00 = Direct convention.<br>01 = Reserved.<br>10 = Reserved.<br>11 = Inverse convention.<br><b>Note:</b> If AUTOSEN (SCn_CTL[3]) is enabled, this field is ignored.                                                                                                                                                                                                                                                                                         |
| [3]     | <b>AUTOCEN</b> | <b>Auto Convention Enable Bit</b><br>This bit is used for enable auto convention function.<br>0 = Auto-convention Disabled.<br>1 = Auto-convention Enabled.                                                                                                                                                                                                                                                                                                                               |

|     |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |              | If user enables auto convention function, the setting step must be done before Answer to Reset (ATR) state and the first data must be 0x3B or 0x3F. After hardware received first data and stored it at buffer, hardware will decide the convention and change the CONSEL (SCn_CTL[5:4]) bits automatically when received first data is 0x3B or 0x3F. If received first byte is 0x3B, 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><br>If the first data is not 0x3B or 0x3F, hardware will set ACERRIF (SCn_INTSTS[10]) and generate an interrupt to CPU when ACERRIEN (SCn_INTEN[10]) is enabled. |
| [2] | <b>TXOFF</b> | <b>TX Transition Disable Control Bit</b><br><br>This bit is used for disable Tx transition function.<br>0 = The transceiver Enabled.<br>1 = The transceiver Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [1] | <b>RXOFF</b> | <b>RX Transition Disable Control Bit</b><br><br>This bit is used for disable Rx transition function.<br>0 = The receiver Enabled.<br>1 = The receiver Disabled.<br><b>Note:</b> If AUTOSEN (SCn_CTL[3]) is enabled, this field is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [0] | <b>SCEN</b>  | <b>SC Controller Enable Bit</b><br><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><b>Note:</b> 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+0x08 | R/W | SC Alternate Control Register |  |  |  | 0x0000_0000 |

|          |          |         |         |        |          |         |       |
|----------|----------|---------|---------|--------|----------|---------|-------|
| 31       | 30       | 29      | 28      | 27     | 26       | 25      | 24    |
| SYNC     | Reserved |         |         |        |          |         |       |
| 23       | 22       | 21      | 20      | 19     | 18       | 17      | 16    |
| Reserved |          |         |         |        |          |         |       |
| 15       | 14       | 13      | 12      | 11     | 10       | 9       | 8     |
| ACTSTS2  | ACTSTS1  | ACTSTS0 | RXBGTEN | ADACEN | Reserved | INITSEL |       |
| 7        | 6        | 5       | 4       | 3      | 2        | 1       | 0     |
| CNTEN2   | CNTEN1   | CNTEN0  | WARSTEN | ACTEN  | DACTEN   | RXRST   | TXRST |

| Bits    | Description |                                                                                                                                                                                                                                                                        |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | SYNC        | <b>SYNC Flag Indicator (Read Only)</b><br>Due to synchronization, user should check this bit when writing a new value to SCn_ALTCTL register.<br>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     | <b>Internal Timer2 Active Status (Read Only)</b><br>This bit indicates the timer counter status of timer2.<br>0 = Timer2 is not active.<br>1 = Timer2 is active.<br><b>Note:</b> Timer2 is active does not always mean timer2 is counting the CNT (SCn_TMRCTL2[7:0]).  |
| [14]    | ACTSTS1     | <b>Internal Timer1 Active Status (Read Only)</b><br>This bit indicates the timer counter status of timer1.<br>0 = Timer1 is not active.<br>1 = Timer1 is active.<br><b>Note:</b> Timer1 is active does not always mean timer1 is counting the CNT (SCn_TMRCTL1[7:0]).  |
| [13]    | ACTSTS0     | <b>Internal Timer0 Active Status (Read Only)</b><br>This bit indicates the timer counter status of timer0.<br>0 = Timer0 is not active.<br>1 = Timer0 is active.<br><b>Note:</b> Timer0 is active does not always mean timer0 is counting the CNT (SCn_TMRCTL0[23:0]). |
| [12]    | RXBGTEN     | <b>Receiver Block Guard Time Function Enable Bit</b><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]  | <b>ADACEN</b>   | <b>Auto Deactivation When Card Removal</b><br>This bit is used for enable hardware auto deactivation when smart card is removed.<br>0 = Auto deactivation Disabled.<br>1 = Auto deactivation Enabled.<br><b>Note:</b> When the card is removed, hardware will stop any process and then do deactivation sequence if this bit is set. If auto deactivation process completes, hardware will set INITIF (SCn_INTSTS[8]) also.                                                                                                                                                                                                          |
| [10]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [9:8] | <b>INITSEL</b>  | <b>Initial Timing Selection</b><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.17-54.<br>Warm-reset: refer to Warm-Reset Sequence in Figure 6.17-55.<br>Deactivation: refer to Deactivation Sequence in Figure 6.17-56.<br><b>Note:</b> When set activation and warm reset in Timer0 operation mode 0011, it may have deviation at most 128 SC module clock cycles.                                                                                                    |
| [7]   | <b>CNTEN2</b>   | <b>Internal Timer2 Start Enable Bit</b><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.<br>0 = Stops counting.<br>1 = Start counting.<br><b>Note1:</b> 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><b>Note2:</b> If the operation mode is not in auto-reload mode (SCn_TMRCTL2[26] = 0), this bit will be auto-cleared by hardware.<br><b>Note3:</b> If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed. |
| [6]   | <b>CNTEN1</b>   | <b>Internal Timer1 Start Enable Bit</b><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.<br>0 = Stops counting.<br>1 = Start counting.<br><b>Note1:</b> 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><b>Note2:</b> If the operation mode is not in auto-reload mode (SCn_TMRCTL1[26] = 0), this bit will be auto-cleared by hardware.<br><b>Note3:</b> If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed.     |
| [5]   | <b>CNTEN0</b>   | <b>Internal Timer0 Start Enable Bit</b><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.<br>0 = Stops counting.<br>1 = Start counting.<br><b>Note1:</b> This field is used for internal 24 bit timer when TMRSEL (SCn_CTL[14:13]) is 11 only.<br><b>Note2:</b> If the operation mode is not in auto-reload mode (SCn_TMRCTL0[26] = 0), this bit will be auto-cleared by hardware.<br><b>Note3:</b> If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed.                                                                       |
| [4]   | <b>WARSTEN</b>  | <b>Warm Reset Sequence Generator Enable Bit</b><br>This bit enables SC controller to initiate the card by warm reset sequence.<br>0 = No effect.<br>1 = Warm reset sequence generator Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | <p><b>Note1:</b> When the warm reset sequence completed, this bit will be cleared automatically and the INITIF (SCn_INTSTS[8]) will be set to 1.</p> <p><b>Note2:</b> 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.</p> <p><b>Note3:</b> If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed.</p> <p><b>Note4:</b> During the warm reset sequence, RX is disabled automatically and can not receive data. After the warm reset sequence completion, RXOFF (SCn_CTL[1]) keeps the state before perform warm reset sequence.</p>                                                                                                                                                                                                         |
| [3] | ACTEN  | <p><b>Activation Sequence Generator Enable Bit</b></p> <p>This bit enables SC controller to initiate the card by activation sequence.</p> <p>0 = No effect.</p> <p>1 = Activation sequence generator Enabled.</p> <p><b>Note1:</b> When the activation sequence completed, this bit will be cleared automatically and the INITIF (SCn_INTSTS[8]) will be set to 1.</p> <p><b>Note2:</b> This field will be cleared by TXRST (SCn_ALTCTL[0]) and RXRST (SCn_ALTCTL[1]). Thus, do not fill in this bit ACTEN, TXRST and RXRST at the same time.</p> <p><b>Note3:</b> If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed.</p> <p><b>Note4:</b> During the activation sequence, RX is disabled automatically and can not receive data. After the activation sequence completion, RXOFF (SCn_CTL[1]) keeps the state before hardware activation.</p> |
| [2] | DACTEN | <p><b>Deactivation Sequence Generator Enable Bit</b></p> <p>This bit enables SC controller to initiate the card by deactivation sequence.</p> <p>0 = No effect.</p> <p>1 = Deactivation sequence generator Enabled.</p> <p><b>Note1:</b> When the deactivation sequence completed, this bit will be cleared automatically and the INITIF (SCn_INTSTS[8]) will be set to 1.</p> <p><b>Note2:</b> This field will be cleared by TXRST (SCn_ALTCTL[0]) and RXRST (SCn_ALTCTL[1]). Thus, do not fill in this bit DACTEN, TXRST and RXRST at the same time.</p> <p><b>Note3:</b> If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed.</p>                                                                                                                                                                                                             |
| [1] | RXRST  | <p><b>Rx Software Reset</b></p> <p>When RXRST is set, all the bytes in the receive buffer and Rx internal state machine will be cleared.</p> <p>0 = No effect.</p> <p>1 = Reset the Rx internal state machine and pointers.</p> <p><b>Note:</b> This bit will be auto cleared after reset is complete.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [0] | TXRST  | <p><b>TX Software Reset</b></p> <p>When TXRST is set, all the bytes in the transmit buffer and TX internal state machine will be cleared.</p> <p>0 = No effect.</p> <p>1 = Reset the TX internal state machine and pointers.</p> <p><b>Note:</b> This bit will be auto cleared after reset is complete.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**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 | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                         |
| [7:0]  | EGT         | <p><b>Extra Guard Time</b></p> <p>This field indicates the extra guard time value.</p> <p><b>Note:</b> The extra guard time unit is ETU base.</p> |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [8:0]  | RFTM        | <p><b>SC Receiver FIFO Time-out Counter</b></p> <p>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.</p> <p><b>Note1:</b> The counter unit is ETU based and the interval of time-out is RFTM + 0.5.</p> <p><b>Note2:</b> Filling in all 0 to this field indicates to disable this function.</p> |

**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 |  |  |  | 0x0000_0173 |

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

| Bits    | Description |                                                                                                                                                                                                   |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                         |
| [11:0]  | ETURDIV     | <b>ETU Rate Divider</b><br>The field is used for ETU clock rate divider.<br>The real ETU is ETURDIV + 1.<br><b>Note:</b> 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 |  |  |  | 0x0000_0000 |

|          |        |         |         |         |          |         |         |
|----------|--------|---------|---------|---------|----------|---------|---------|
| 31       | 30     | 29      | 28      | 27      | 26       | 25      | 24      |
| Reserved |        |         |         |         |          |         |         |
| 23       | 22     | 21      | 20      | 19      | 18       | 17      | 16      |
| Reserved |        |         |         |         |          |         |         |
| 15       | 14     | 13      | 12      | 11      | 10       | 9       | 8       |
| Reserved |        |         |         |         | ACERRIEN | RXTOIEN | INITIEN |
| 7        | 6      | 5       | 4       | 3       | 2        | 1       | 0       |
| CDIEN    | BGTIEN | TMR2IEN | TMR1IEN | TMR0IEN | TERRIEN  | TBEIEN  | RDAIEN  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |
| [10]    | ACERRIEN    | <b>Auto Convention Error Interrupt Enable Bit</b><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     | <b>Receiver Buffer Time-out Interrupt Enable Bit</b><br>This field is used to enable receiver buffer time-out interrupt.<br>0 = Receiver buffer time-out interrupt Disabled.<br>1 = Receiver buffer time-out interrupt Enabled.                                                                               |
| [8]     | INITIEN     | <b>Initial End Interrupt Enable Bit</b><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.<br>0 = Initial end interrupt Disabled.<br>1 = Initial end interrupt Enabled. |
| [7]     | CDIEN       | <b>Card Detect Interrupt Enable Bit</b><br>This field is used to enable card detect interrupt. The card detect status is CDPINSTS (SCn_STATUS[13]).<br>0 = Card detect interrupt Disabled.<br>1 = Card detect interrupt Enabled.                                                                              |
| [6]     | BGTIEN      | <b>Block Guard Time Interrupt Enable Bit</b><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><b>Note:</b> This bit is valid only for receive direction block guard time.           |
| [5]     | TMR2IEN     | <b>Timer2 Interrupt Enable Bit</b><br>This field is used to enable Timer2 interrupt function.                                                                                                                                                                                                                 |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                | 0 = Timer2 interrupt Disabled.<br>1 = Timer2 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [4] | <b>TMR1IEN</b> | <b>Timer1 Interrupt Enable Bit</b><br>This field is used to enable the Timer1 interrupt function.<br>0 = Timer1 interrupt Disabled.<br>1 = Timer1 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [3] | <b>TMR0IEN</b> | <b>Timer0 Interrupt Enable Bit</b><br>This field is used to enable Timer0 interrupt function.<br>0 = Timer0 interrupt Disabled.<br>1 = Timer0 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [2] | <b>TERRIEN</b> | <b>Transfer Error Interrupt Enable Bit</b><br>This field is used to enable transfer error interrupt. 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]), 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]) and transmitter retry over limit error TXOVERR (SCn_STATUS[30]).<br>0 = Transfer error interrupt Disabled.<br>1 = Transfer error interrupt Enabled. |
| [1] | <b>TBEIEN</b>  | <b>Transmit Buffer Empty Interrupt Enable Bit</b><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] | <b>RDAIEN</b>  | <b>Receive Data Reach Interrupt Enable Bit</b><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 |  |  |  | 0x0000_0002 |

|          |       |        |        |        |         |        |        |
|----------|-------|--------|--------|--------|---------|--------|--------|
| 31       | 30    | 29     | 28     | 27     | 26      | 25     | 24     |
| Reserved |       |        |        |        |         |        |        |
| 23       | 22    | 21     | 20     | 19     | 18      | 17     | 16     |
| Reserved |       |        |        |        |         |        |        |
| 15       | 14    | 13     | 12     | 11     | 10      | 9      | 8      |
| Reserved |       |        |        |        | ACERRIF | RXTOIF | INITIF |
| 7        | 6     | 5      | 4      | 3      | 2       | 1      | 0      |
| CDIF     | BGTIF | TMR2IF | TMR1IF | TMR0IF | TERRIF  | TBEIF  | RDAIF  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                      |
| [10]    | ACERRIF     | <b>Auto Convention Error Interrupt Status Flag</b><br>This field indicates auto convention sequence error.<br>0 = Received TS at ATR state is 0x3B or 0x3F.<br>1 = Received TS at ATR state is neither 0x3B nor 0x3F.<br><b>Note:</b> This bit can be cleared by writing 1 to it.                                                                                                              |
| [9]     | RXTOIF      | <b>Receive Buffer Time-out Interrupt Status Flag (Read Only)</b><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><b>Note:</b> This bit is read only, user must read all receive buffer remaining data by reading SCn_DAT register to clear it. |
| [8]     | INITIF      | <b>Initial End Interrupt Status Flag</b><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><b>Note:</b> This bit can be cleared by writing 1 to it.                               |
| [7]     | CDIF        | <b>Card Detect Interrupt Status Flag (Read Only)</b><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><b>Note:</b> This bit is read only, user must to clear CINSERT or CREMOVE status to clear it.                 |
| [6]     | BGTIF       | <b>Block Guard Time Interrupt Status Flag</b><br>This field is used for indicate block guard time interrupt status flag in receive direction.<br>0 = Block guard time interrupt did not occur.                                                                                                                                                                                                 |

|     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | 1 = Block guard time interrupt occurred.<br><br><b>Note1:</b> This bit is valid only when RXBGTE (SCn_ALTCTL[12]) is enabled.<br><b>Note2:</b> This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [5] | TMR2IF | <b>Timer2 Interrupt Status Flag</b><br>This field is used for Timer2 interrupt status flag.<br>0 = Timer2 interrupt did not occur.<br>1 = Timer2 interrupt occurred.<br><b>Note:</b> This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [4] | TMR1IF | <b>Timer1 Interrupt Status Flag</b><br>This field is used for Timer1 interrupt status flag.<br>0 = Timer1 interrupt did not occur.<br>1 = Timer1 interrupt occurred.<br><b>Note:</b> This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [3] | TMR0IF | <b>Timer0 Interrupt Status Flag</b><br>This field is used for Timer0 interrupt status flag.<br>0 = Timer0 interrupt did not occur.<br>1 = Timer0 interrupt occurred.<br><b>Note:</b> This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2] | TERRIF | <b>Transfer Error Interrupt Status Flag</b><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><b>Note1:</b> This field is the status flag of BEF, FEF, PEF, RXOV, TXOV, RXOVERR or TXOVERR.<br><b>Note2:</b> This bit can be cleared by writing 1 to it. |
| [1] | TBEIF  | <b>Transmit Buffer Empty Interrupt Status Flag (Read Only)</b><br>This field is used for transmit buffer empty interrupt status flag.<br>0 = Transmit buffer is not empty.<br>1 = Transmit buffer is empty.<br><b>Note:</b> 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  | <b>Receive Data Ready Interrupt Status Flag (Read Only)</b><br>This field is used for received data reaching trigger level RXTRGLV (SCn_CTL[7:6]) interrupt status flag.<br>0 = Number of receive buffer is less than RXTRGLV setting.<br>1 = Number of receive buffer data equals the RXTRGLV setting.<br><b>Note:</b> 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+0x20 | R/W | SC Transfer Status Register |  |  |  | 0x0000_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 | RFULL   | REMPY   | RXOV |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | TXACT       | <p><b>Transmit in Active Status Flag (Read Only)</b><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.</p> |
| [30]    | TXOVERR     | <p><b>Transmitter over Retry Error</b><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/><b>Note:</b> This bit can be cleared by writing 1 to it.</p>                  |
| [29]    | TXRERR      | <p><b>Transmitter Retry Error</b><br/>This bit is used for indicate transmitter error retry and set by hardware..<br/>0 = No Tx retry transfer.<br/>1 = Tx has any error and retries transfer.<br/><b>Note1:</b> This bit can be cleared by writing 1 to it.<br/><b>Note2:</b> This bit is a flag and cannot generate any interrupt to CPU.</p>                              |
| [28:27] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |
| [26:24] | TXPOINT     | <p><b>Transmit Buffer Pointer Status (Read Only)</b><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.</p>                                                                                                    |
| [23]    | RXACT       | <p><b>Receiver in Active Status Flag (Read Only)</b><br/>This bit indicates Rx transfer status.<br/>0 = This bit is cleared automatically when Rx transfer is finished.<br/>1 = This bit is set by hardware when Rx transfer is in active.</p>                                                                                                                               |
| [22]    | RXOVERR     | <b>Receiver over Retry Error</b>                                                                                                                                                                                                                                                                                                                                             |

|         |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | This bit is used for receiver retry counts over than retry number limitation.<br>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><b>Note1:</b> This bit can be cleared by writing 1 to it.<br><b>Note2:</b> If CPU enables receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag.                 |
| [21]    | RXRERR   | <b>Receiver Retry Error</b><br>This bit is used for receiver error retry and set by hardware.<br>0 = No Rx retry transfer.<br>1 = Rx has any error and retries transfer.<br><b>Note1:</b> This bit can be cleared by writing 1 to it.<br><b>Note2:</b> This bit is a flag and cannot generate any interrupt to CPU.<br><b>Note3:</b> 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  | <b>Receive Buffer Pointer Status (Read Only)</b><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 | <b>Card Detect Pin Status (Read Only)</b><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  | <b>Card Insert Status of SCn_CD Pin</b><br>This bit is set whenever card has been inserted.<br>0 = No effect.<br>1 = Card insert.<br><b>Note1:</b> This bit can be cleared by writing "1" to it.<br><b>Note2:</b> The card detect function will start after SCEN (SCn_CTL[0]) set.                                                                                                                                                               |
| [11]    | CREMOVE  | <b>Card Removal Status of SCn_CD Pin</b><br>This bit is set whenever card has been removal.<br>0 = No effect.<br>1 = Card removed.<br><b>Note1:</b> This bit can be cleared by writing "1" to it.<br><b>Note2:</b> Card detect function will start after SCEN (SCn_CTL[0]) set.                                                                                                                                                                  |
| [10]    | TXFULL   | <b>Transmit Buffer Full Status Flag (Read Only)</b><br>This bit indicates Tx buffer full or not.<br>0 = Tx buffer count is less than 4.<br>1 = Tx buffer count equals to 4.                                                                                                                                                                                                                                                                      |
| [9]     | TXEMPTY  | <b>Transmit Buffer Empty Status Flag (Read Only)</b><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><b>Note:</b> This bit will be cleared when writing data into DAT (SCn_DAT[7:0]).                                                                                                         |
| [8]     | TXOV     | <b>Transmit Overflow Error Interrupt Status Flag</b>                                                                                                                                                                                                                                                                                                                                                                                             |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | <p>This bit is set when Tx buffer overflow.</p> <p>0 = Tx buffer is not overflow.</p> <p>1 = Tx buffer is overflow when Tx buffer is full and an additional write operation to DAT (SCn_DAT[7:0]).</p> <p><b>Note:</b> This bit can be cleared by writing 1 to it.</p>                                                                                                                                                                                                                                                                                                                           |
| [7] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [6] | <b>BEF</b>      | <p><b>Receiver Break Error Status Flag</b></p> <p>This bit is set to logic 1 whenever the received data input (Rx) held in the "spacing state" (logic 0) is longer than a full word transmission time (that is, the total time of "start bit" + "data bits" + "parity bit" + "stop bits").</p> <p>0 = Receiver break error flag did not occur.</p> <p>1 = Receiver break error flag occurred.</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> If CPU sets receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag.</p> |
| [5] | <b>FEF</b>      | <p><b>Receiver Frame Error Status Flag</b></p> <p>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).</p> <p>0 = Receiver frame error flag did not occur.</p> <p>1 = Receiver frame error flag occurred.</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> If CPU sets receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag.</p>                                                    |
| [4] | <b>PEF</b>      | <p><b>Receiver Parity Error Status Flag</b></p> <p>This bit is set to logic 1 whenever the received character does not have a valid "parity bit".</p> <p>0 = Receiver parity error flag did not occur.</p> <p>1 = Receiver parity error flag occurred.</p> <p><b>Note1:</b> This bit can be cleared by writing 1 to it.</p> <p><b>Note2:</b> If CPU sets receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag.</p>                                                                                                                                        |
| [3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [2] | <b>RXFULL</b>   | <p><b>Receive Buffer Full Status Flag (Read Only)</b></p> <p>This bit indicates Rx buffer full or not.</p> <p>0 = Rx buffer count is less than 4.</p> <p>1 = Rx buffer count equals to 4.</p>                                                                                                                                                                                                                                                                                                                                                                                                    |
| [1] | <b>RXEMPTY</b>  | <p><b>Receive Buffer Empty Status Flag (Read Only)</b></p> <p>This bit indicates Rx buffer empty or not.</p> <p>0 = Rx buffer is not empty.</p> <p>1 = Rx buffer is empty, it means the last byte of Rx buffer has read from DAT (SCn_DAT[7:0]) by CPU.</p>                                                                                                                                                                                                                                                                                                                                      |
| [0] | <b>RXOV</b>     | <p><b>Receive Overflow Error Status Flag</b></p> <p>This bit is set when Rx buffer overflow.</p> <p>0 = Rx buffer is not overflow.</p> <p>1 = Rx buffer is overflow when the number of received bytes is greater than Rx buffer size (4 bytes).</p> <p><b>Note:</b> This bit can be cleared by writing 1 to it.</p>                                                                                                                                                                                                                                                                              |

**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        | <b>SYNC Flag Indicator (Read Only)</b><br>Due to synchronization, user should check this bit when writing a new value to SCn_PINCTL register.<br>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      | <b>SCn_RST Pin Status (Read Only)</b><br>This bit is the pin status of SCn_RST.<br>0 = SCn_RST pin is low.<br>1 = SCn_RST pin is high.                                                                                                                                                                                              |
| [17]    | PWRSTS      | <b>SCn_PWR Pin Status (Read Only)</b><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     | <b>SCn_DATA Pin Status (Read Only)</b><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      | <b>SCn_PWR Pin Inverse</b><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,<br>00 = SCn_PWR pin is 0. |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | <p>01 = SCn_PWR pin is 1.<br/>10 = SCn_PWR pin is 1.<br/>11 = SCn_PWR pin is 0.</p> <p><b>Note:</b> User must select PWRINV (SCn_PINCTL[11]) before smart card is enabled by SCEN (SCn_CTL[0]).</p>                                                                                                                                                                                                                                                                                                                                                                                                           |
| [10]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [9]   | <b>SCDATA</b>   | <p><b>SCn_DATA Pin Signal</b><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.<br/>0 = Drive SCn_DATA pin to low.<br/>1 = Drive SCn_DATA pin to high.<br/>Read this field to get SCn_DATA signal status.<br/>0 = SCn_DATA signal status is low.<br/>1 = SCn_DATA signal status is high.</p> <p><b>Note:</b> 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.</p>                                                                |
| [8:7] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [6]   | <b>CLKKEEP</b>  | <p><b>SC Clock Enable Bit</b><br/>0 = SC clock generation Disabled.<br/>1 = SC clock always keeps free running.</p> <p><b>Note:</b> When operating in activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes.</p>                                                                                                                                                                                                                                                                                                 |
| [5:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [1]   | <b>RSTEN</b>    | <p><b>SCn_RST Pin Signal</b><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.</p> <p><b>Note:</b> When operating at activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes.</p>                                               |
| [0]   | <b>PWREN</b>    | <p><b>SCn_PWR Pin Signal</b><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.</p> <p><b>Note:</b> When operating at activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes</p> |

**SC Timer0 Control Register (SC\_TMRCTL0)**

| Register          | Offset      | R/W | Description                         |  |  |  |  | Reset Value |
|-------------------|-------------|-----|-------------------------------------|--|--|--|--|-------------|
| <b>SC_TMRCTL0</b> | SCn_BA+0x28 | R/W | SC Internal Timer0 Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                             |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>SYNC</b>     | <b>SYNC Flag Indicator (Read Only)</b><br>Due to synchronization, user should check this bit when writing a new value to the SCn_TMRCTL0 register.<br>0 = Synchronizing is completion, user can write new data to SCn_TMRCTL0 register.<br>1 = Last value is synchronizing. |
| [30:28] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                   |
| [27:24] | <b>OPMODE</b>   | <b>Timer0 Operation Mode Selection</b><br>This field indicates the internal 24-bit Timer0 operation selection.<br>Refer to Table 6.17-3 for programming Timer0.                                                                                                             |
| [23:0]  | <b>CNT</b>      | <b>Timer0 Counter Value</b><br>This field indicates the internal Timer0 counter values.<br><b>Note:</b> 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 |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                             |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>SYNC</b>     | <b>SYNC Flag Indicator (Read Only)</b><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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                   |
| [27:24] | <b>OPMODE</b>   | <b>Timer 1 Operation Mode Selection</b><br>This field indicates the internal 8-bit Timer1 operation selection.<br>Refer to Table 6.17-3 for programming Timer1.                                                                                                             |
| [23:8]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                   |
| [7:0]   | <b>CNT</b>      | <b>Timer 1 Counter Value</b><br>This field indicates the internal Timer1 counter values.<br><b>Note:</b> Unit of Timer1 counter is ETU base.                                                                                                                                |

**SC Timer2 Control Register (SC\_TMRCTL2)**

| Register   | Offset      | R/W | Description                         |  |  |  |  | Reset Value |
|------------|-------------|-----|-------------------------------------|--|--|--|--|-------------|
| SC_TMRCTL2 | SCn_BA+0x30 | R/W | SC Internal Timer2 Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                         |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>SYNC</b>     | <b>SYNC Flag Indicator (Read Only)</b><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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                               |
| [27:24] | <b>OPMODE</b>   | <b>Timer 2 Operation Mode Selection</b><br>This field indicates the internal 8-bit Timer2 operation selection<br>Refer to Table 6.17-3 for programming Timer2.                                                                                                          |
| [23:8]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                               |
| [7:0]   | <b>CNT</b>      | <b>Timer 2 Counter Value</b><br>This field indicates the internal Timer2 counter values.<br><b>Note:</b> 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+0x34 | R/W | SC UART Mode Control Register | 0x0000_0000 |

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [7]    | <b>OPE</b>      | <p><b>Odd Parity Enable Bit</b><br/> This is used for odd/even parity selection.<br/> 0 = Even number of logic 1 are transmitted or check the data word and parity bits in receiving mode.<br/> 1 = Odd number of logic 1 are transmitted or check the data word and parity bits in receiving mode.<br/> <b>Note:</b> This bit has effect only when PBOFF bit is 0.</p>                                                                                                          |
| [6]    | <b>PBOFF</b>    | <p><b>Parity Bit Disable Bit</b><br/> Sets this bit is used for disable parity check function.<br/> 0 = Parity bit is generated or checked between the “last data word bit” and “stop bit” of the serial data.<br/> 1 = Parity bit is not generated (transmitting data) or checked (receiving data) during transfer.<br/> <b>Note:</b> In smart card mode, this field must be 0 (default setting is with parity bit).</p>                                                        |
| [5:4]  | <b>WLS</b>      | <p><b>Word Length Selection</b><br/> This field is used for select UART data length.<br/> 00 = Word length is 8 bits.<br/> 01 = Word length is 7 bits.<br/> 10 = Word length is 6 bits.<br/> 11 = Word length is 5 bits.<br/> <b>Note:</b> In smart card mode, this WLS must be 00.</p>                                                                                                                                                                                          |
| [3:1]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [0]    | <b>UARTEN</b>   | <p><b>UART Mode Enable Bit</b><br/> Sets this bit to enable UART mode function.<br/> 0 = Smart Card mode.<br/> 1 = UART mode.<br/> <b>Note1:</b> When operating in UART mode, user must set CONSEL (SCn_CTL[5:4]) = 00 and AUTOCEN (SCn_CTL[3]) = 0.<br/> <b>Note2:</b> When operating in Smart Card mode, user must set UARTEN (SCn_UARTCTL[0]) = 0.<br/> <b>Note3:</b> When UART mode is enabled, hardware will generate a reset to reset FIFO and internal state machine.</p> |

**SC Activation Control Register (SC\_ACTCTL)**

| Register  | Offset      | R/W | Description                    |  |  |  |  | Reset Value |
|-----------|-------------|-----|--------------------------------|--|--|--|--|-------------|
| SC_ACTCTL | SCn_BA+0x4C | R/W | SC Activation 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 |    |    | T1EXT |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [4:0]  | T1EXT       | <p><b>T1 Extend Time of Hardware Activation</b></p> <p>This field provide the configurable cycles to extend the activation time T1 period.</p> <p>The cycle scaling factor is 2048.</p> <p>Extend cycles = (filled value * 2048) cycles.</p> <p>Refer to SC activation sequence in Figure 6.17-4.</p> <p>For example,</p> <p>SCLK = 4MHz, each cycle = 0.25us.,</p> <p>Filled 20 to this field</p> <p>Extend time = 20 * 2048 * 0.25us = 10.24 ms.</p> <p><b>Note:</b> Setting 0 to this field conforms to the protocol ISO/IEC 7816-3</p> |

## 6.18 I<sup>2</sup>S Controller (I<sup>2</sup>S)

### 6.18.1 Overview

The I<sup>2</sup>S controller consists of I<sup>2</sup>S protocol to interface with external audio CODEC. Two 16-level depth FIFO for reading path and writing path respectively are capable of handling 8/16/24/32 bits audio data sizes. A PDMA controller handles the data movement between FIFO and memory.

### 6.18.2 Features

- Supports Master mode and Slave mode
- Capable of handling 8, 16, 24 and 32 bits data sizes in each audio channel
- Supports monaural and stereo audio data
- Supports I<sup>2</sup>S protocols: Philips standard, MSB-justified, and LSB-justified data format
- Supports PCM protocols: PCM standard, MSB-justified, and LSB-justified data format
- PCM protocol supports TDM multi-channel transmission in one audio sample, and the number of data channel can be set as 2, 4, 6, or 8
- Provides two 16-level FIFO data buffers, one for transmitting and the other for receiving
- Generates interrupt requests when buffer levels cross a programmable boundary
- Supports two PDMA requests, one for transmitting and the other for receiving

### 6.18.3 Block Diagram



Figure 6.18-1 I<sup>2</sup>S Controller Block Diagram

### 6.18.4 Basic Configuration

#### 6.18.4.1 I<sup>2</sup>S Basic Configuration

- Clock source Configuration

- Select the source of I<sup>2</sup>S peripheral clock on I2S0SEL (CLK\_CLKSEL3[17:16]).
- Enable I<sup>2</sup>S peripheral clock in I2S0CKEN (CLK\_APBCLK0[29]).
- Reset Configuration
  - Reset I<sup>2</sup>S controller in I2S0RST (SYS\_IPRST1[29]).
- Pin configuration

| Group | Pin Name  | GPIO        | MFP   |
|-------|-----------|-------------|-------|
| I2S0  | I2S0_BCLK | PA.12       | MFP2  |
|       |           | PE.8, PF.10 | MFP4  |
|       |           | PE.1        | MFP5  |
|       |           | PC.4        | MFP6  |
|       |           | PB.5        | MFP10 |
|       | I2S0_DI   | PA.14       | MFP2  |
|       |           | PE.10, PF.8 | MFP4  |
|       |           | PH.8        | MFP5  |
|       |           | PC.2        | MFP6  |
|       |           | PB.3        | MFP10 |
|       | I2S0_DO   | PA.15       | MFP2  |
|       |           | PE.11, PF.7 | MFP4  |
|       |           | PH.9        | MFP5  |
|       |           | PC.1        | MFP6  |
|       |           | PB.2        | MFP10 |
|       | I2S0_LRCK | PE.12, PF.6 | MFP4  |
|       |           | PH.10       | MFP5  |
|       |           | PC.0        | MFP6  |
|       |           | PB.1        | MFP10 |
|       | I2S0_MCLK | PA.13       | MFP2  |
|       |           | PE.9, PF.9  | MFP4  |
|       |           | PE.0        | MFP5  |
|       |           | PC.3        | MFP6  |
|       |           | PB.4        | MFP10 |

Table 6.18-2 Pin Configuration of I<sup>2</sup>S Controller

### 6.18.5 Functional Description

#### 6.18.5.1 I<sup>2</sup>S Clock

The I<sup>2</sup>S controller has four clock sources selected by I2S0SEL (CLK\_CLKSEL3[17:16]). The I<sup>2</sup>S clock rate must be slower than or equal to system clock rate.

Figure 6.18-3 I<sup>2</sup>S Clock Control Diagram

#### 6.18.5.2 Master/Slave Interface

The I<sup>2</sup>S function can operate as master or slave mode by setting SLAVE (I<sup>2</sup>S\_CTL0[8]) to communicate with other I<sup>2</sup>S slave or master. The serial bus clock I<sup>2</sup>S\_BCLK is permanently generated by the master even though there is no transferring data bit at the moment. The word select signal I<sup>2</sup>S\_LRCLK is also generated by the master and it indicates the beginning of a new data word and the targeted audio channel. Both the I<sup>2</sup>S\_LRCLK and the transmitting data change synchronously to the falling edges of I<sup>2</sup>S\_BCLK.

In some applications, especially for Audio-ADC or Audio-DAC, a master clock signal, I<sup>2</sup>S\_MCLK, is required with a fixed phase relation to the I<sup>2</sup>S\_BCLK. The I<sup>2</sup>S\_MCLK is enabled by MCLKEN (I<sup>2</sup>S\_CTL0[15]). In Master mode, the I<sup>2</sup>S\_MCLK, I<sup>2</sup>S\_BCLK, I<sup>2</sup>S\_LRCLK is output to device slave. And if in slave mode, the I<sup>2</sup>S\_MCLK is output to master, and I<sup>2</sup>S\_BCLK or I<sup>2</sup>S\_LRCLK is input from master.



Figure 6.18-4 Master Mode Interface Block Diagram



Figure 6.18-5 Slave Mode Interface Block Diagram

#### 6.18.5.3 I<sup>2</sup>S Operation

The I<sup>2</sup>S controller supports MSB-justified, LSB-justified, and I<sup>2</sup>S Philips standard data format. The

I<sup>2</sup>S\_LRCLK signal indicates which audio channel is in transferring. The bit count of an audio channel is defined by CHWIDTH (I<sup>2</sup>S\_CTL0[29:28]), and the bit-width of data word in an audio channel is determined by DATWIDTH (I<sup>2</sup>S\_CTL0[5:4]). If CHWIDTH (I<sup>2</sup>S\_CTL0[29:28]) is less than DATWIDTH (I<sup>2</sup>S\_CTL0[5:4]), the hardware will set the channel bit-width to be same as data bit-width. However, there will be redundant zero bits in each audio channel if CHWIDTH (I<sup>2</sup>S\_CTL0[29:28]) is greater than DATWIDTH (I<sup>2</sup>S\_CTL0[5:4]).



Figure 6.18-6 I<sup>2</sup>S Channel Width and Data Width ( $\text{CHWIDTH} \leq \text{DATWIDTH}$ )



Figure 6.18-7 I<sup>2</sup>S Channel Width and Data Width ( $\text{CHWIDTH} > \text{DATWIDTH}$ )

The transferring data sequence is always started from the MSB (most significant bit) to the LSB (least significant bit). As shown in Figure 6.18-8, transmitting data are read at rising edge of I<sup>2</sup>S\_BCLK and sent out at falling edge of I<sup>2</sup>S\_BCLK in I<sup>2</sup>S protocol. In I<sup>2</sup>S data format, the MSB is sent and latched at the next falling edge of I<sup>2</sup>S\_BCLK cycle after the transition of I<sup>2</sup>S\_LRCLK. In MSB justified data format, the I<sup>2</sup>S\_LRCLK changes the polarity at the transmitting of the first data bit (MSB) in each audio channel. In LSB justified data format, the LSB is sent and latched at the last I<sup>2</sup>S\_BCLK cycle of an audio channel. The MSB justified and LSB justified data format of I<sup>2</sup>S protocol can be selected by FORMAT (I<sup>2</sup>S\_CTL0[26:24]).



Figure 6.18-8 I<sup>2</sup>S Data Format Timing Diagram (FORMAT = 0x0 ; CHWIDTH≤DATWIDTH)

Figure 6.18-9 MSB Justified Data Format (FORMAT = 0x1 ; CHWIDTH &gt; DATWIDTH)



Figure 6.18-10 LSB Justified Data Format (FORMAT = 0x2 ; CHWIDTH &gt; DATWIDTH)

The I<sup>2</sup>S controller also supports PCM audio transmission which can be selected by FORMAT (I2S\_CTL0[26:24]). In PCM protocol, the function of I2S\_LRCLK is simply to identify the beginning of an audio sample (or audio frame) and it is always indicated by the rising edge of the pulse. Therefore, the I2S\_LRCLK in PCM protocol may be also called “frame start” or “frame sync” signal. In master device, there are two common representations for the width of the frame start pulse which can use PCMSYNC (I2S\_CTL0[27]) to choose: One is equivalent to the period of a channel width and the other is equivalent to a single period of the I2S\_BCLK.

Same as I<sup>2</sup>S protocol, the DATWIDTH (I2S\_CTL0[5:4]) and CHWIDTH (I2S\_CTL0[29:28]) can be used to configure the data bit-width and channel bit-width in PCM protocol. Besides, FORMAT (I2S\_CTL0[26:24]) can also be used to select the different data formats of PCM standard mode, PCM with MSB justified, and PCM with LSB justified data format.



Figure 6.18-11 Standard PCM Audio Timing Diagram (FORMAT = 0x4 ; CHWIDTH≤DATWIDTH)



Figure 6.18-12 PCM with MSB Justified Data Format (FORMAT = 0x5 ; CHWIDTH &gt; DATWIDTH)



Figure 6.18-13 PCM with LSB Justified Data Format (FORMAT = 0x6 ; CHWIDTH &gt; DATWIDTH)

#### 6.18.5.4 TDM Multi-channel Transmission

The PCM mode in this I<sup>2</sup>S controller also supports TDM transmission. The Time Division Multiplexed (TDM) method allows multiple channels of audio data to be transmitted on a single data line. The TDM interface is similar to the 2-channel PCM audio interface with the exception that more audio channels are transmitted within a sample frame which is defined by a period of the I2S\_LRCLK. The channel number of TDM interface is typically 4, 6, or 8 and it is selected by TDMCHNUM (I2S\_CTL0[31:30]).

Same as previous I<sup>2</sup>S and PCM descriptions, each channel block is comprised of the audio data word followed by a sufficient number of zero data bits to complete one channel block. The bit-width of data word and channel block are defined by DATWIDTH (I2S\_CTL0[5:4]) and CHWIDTH (I2S\_CTL0[29:28]) respectively. Note that the TDM PCM mode supports 16-bit, 24-bit, 32-bit audio data word (excluding 8-bit data), and the hardware will set the bit-width of transmitting data as 16-bit if DATWIDTH (I2S\_CTL0[5:4]) is 0x0. The pulse width of frame start signal is also selected by PCMSYNC (I2S\_CTL0[27]).

The examples of 6-channel TDM transmission with 24-bit audio data in 32-bit channel block are shown in Figure 6.18-14. In 2-channel audio interface, the first and second audio channels are called as left-channel and right-channel (or channel0 and channel1). In TDM multi-channel application, the first and second audio channels are called as channel0 and channel1.



Figure 6.18-14 TDM 6-channel Audio Format with 24-bit Data in 32-bit Channel Block (PCM Standard Data Format; FORMAT=0x4)



Figure 6.18-15 TDM 6-channel Audio Format with 24-bit Data in 32-bit Channel Block (PCM with MSB Justified; FORMAT=0x5)



Figure 6.18-16 TDM 6-channel Audio Format with 24-bit Data in 32-bit Channel Block (PCM with LSB Justified; FORMAT=0x6)

#### 6.18.5.5 Zero Crossing

When playing the audio by I<sup>2</sup>S controller, the output transmitting data comes from the memory by PDMA or by CPU. However, there may be some pop noise which induces the uncomfortable hearing if the playing sound volume is changed greatly by user. The zero-crossing event of audio data means the playing sound is relatively silent at the moment. Therefore, the zero-cross interrupt can be used for the indication of gain level adjustment in order to prevent the huge variance of sound volume.

If zero-cross detection of individual audio channel is enabled by the corresponding control bit from CH0ZCEN to CH7ZCEN (I<sup>2</sup>S\_CTL1[0] to I<sup>2</sup>S\_CTL1[7]), the hardware will detect the next transferring data word of the corresponding audio channel whether it is 0 or its MSB has been changed. If zero value or MSB (sign bit) changing of the transmitting audio data has been detected while zero-cross

detection is enabled, the hardware will set the corresponding status bit from CH0ZCIF to CH7ZCIF (I2S\_STATUS1[0] to I2S\_STATUS1[7]) for the audio channel and then keep the output audio data silent (all data bit zero) automatically until the corresponding event status bit is cleared by software.

Therefore, if user wants to modify the audio playing gain, users can enable the zero crossing interrupt function, CH0ZCIEN to CH7ZCIEN (I2S\_IEN[16:23]), to indicate the zero crossing time and to change the audio gain. This will reduce the pop noise.

#### 6.18.5.6 PDMA Mode

The I<sup>2</sup>S function can use PDMA function for transmitting or receiving data access. If the PDMA function of transmitting data is enabled by TXPDMAEN (I2S\_CTL0[20]), the I<sup>2</sup>S controller will generate the request signal and then get transmitting audio data from memory by PDMA IP automatically while TX FIFO is not full. If the PDMA function of receiving data is enabled by RXPDMAEN (I2S\_CTL0[21]), the I<sup>2</sup>S controller will generate the request signal and then the receiving data will be moved into memory by PDMA hardware automatically while the RX FIFO is not empty. Therefore, using PDMA function will save the CPU loading to service other functions.

#### 6.18.5.7 I<sup>2</sup>S Interrupt Sources

The I<sup>2</sup>S controller supports zero-cross interrupt of individual audio channel, transmit FIFO threshold level interrupt, transmit FIFO overflow interrupt and transmit FIFO underflow interrupt in transmit operation. In receive operation, it supports receive FIFO threshold level interrupt, receive FIFO overflow interrupt and receive FIFO underflow interrupt. When I<sup>2</sup>S interrupt occurs, user can check I2STXINT (I2S\_STATUS0[2]) and I2SRXINT (I2S\_STATUS0[1]) flags to recognize the interrupt sources.



Figure 6.18-17 I<sup>2</sup>S Interrupts

#### 6.18.5.8 FIFO Operation

In 2-channel I<sup>2</sup>S or PCM protocol, the bit-width of audio data in a channel block can be 8, 16, 24, or 32 bits. The memory arrangements of audio data for various settings are shown in Figure 6.18-18.

|                                                  |                                                                                                                                                                               |    |                |         |                |         |                |       |       |       |   |       |   |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----------------|---------|----------------|---------|----------------|-------|-------|-------|---|-------|---|
| Mono 8-bit data mode                             | <table border="1"><tr><td>7</td><td>N+3</td><td>0</td><td>7</td><td>N+2</td><td>0</td><td>7</td><td>N+1</td><td>0</td><td>7</td><td>N</td><td>0</td></tr></table>             | 7  | N+3            | 0       | 7              | N+2     | 0              | 7     | N+1   | 0     | 7 | N     | 0 |
| 7                                                | N+3                                                                                                                                                                           | 0  | 7              | N+2     | 0              | 7       | N+1            | 0     | 7     | N     | 0 |       |   |
| Stereo 8-bit data mode, ORDER (I2S_CTL0[7]) = 0  | <table border="1"><tr><td>7</td><td>LEFT+1</td><td>0</td><td>7</td><td>RIGHT+1</td><td>0</td><td>7</td><td>LEFT</td><td>0</td><td>7</td><td>RIGHT</td><td>0</td></tr></table> | 7  | LEFT+1         | 0       | 7              | RIGHT+1 | 0              | 7     | LEFT  | 0     | 7 | RIGHT | 0 |
| 7                                                | LEFT+1                                                                                                                                                                        | 0  | 7              | RIGHT+1 | 0              | 7       | LEFT           | 0     | 7     | RIGHT | 0 |       |   |
| Stereo 8-bit data mode, ORDER (I2S_CTL0[7]) = 1  | <table border="1"><tr><td>7</td><td>RIGHT+1</td><td>0</td><td>7</td><td>LEFT+1</td><td>0</td><td>7</td><td>RIGHT</td><td>0</td><td>7</td><td>LEFT</td><td>0</td></tr></table> | 7  | RIGHT+1        | 0       | 7              | LEFT+1  | 0              | 7     | RIGHT | 0     | 7 | LEFT  | 0 |
| 7                                                | RIGHT+1                                                                                                                                                                       | 0  | 7              | LEFT+1  | 0              | 7       | RIGHT          | 0     | 7     | LEFT  | 0 |       |   |
| Mono 16-bit data mode                            | <table border="1"><tr><td>15</td><td colspan="3">N+1</td><td>0</td><td>15</td><td colspan="3">N</td><td>0</td></tr></table>                                                   | 15 | N+1            |         |                | 0       | 15             | N     |       |       | 0 |       |   |
| 15                                               | N+1                                                                                                                                                                           |    |                | 0       | 15             | N       |                |       | 0     |       |   |       |   |
| Stereo 16-bit data mode, ORDER (I2S_CTL0[7]) = 0 | <table border="1"><tr><td>15</td><td colspan="3">LEFT</td><td>0</td><td>15</td><td colspan="3">RIGHT</td><td>0</td></tr></table>                                              | 15 | LEFT           |         |                | 0       | 15             | RIGHT |       |       | 0 |       |   |
| 15                                               | LEFT                                                                                                                                                                          |    |                | 0       | 15             | RIGHT   |                |       | 0     |       |   |       |   |
| Stereo 16-bit data mode, ORDER (I2S_CTL0[7]) = 1 | <table border="1"><tr><td>15</td><td colspan="3">RIGHT</td><td>0</td><td>15</td><td colspan="3">LEFT</td><td>0</td></tr></table>                                              | 15 | RIGHT          |         |                | 0       | 15             | LEFT  |       |       | 0 |       |   |
| 15                                               | RIGHT                                                                                                                                                                         |    |                | 0       | 15             | LEFT    |                |       | 0     |       |   |       |   |
| Mono 24-bit data mode, ORDER (I2S_CTL0[7]) = 0   | <table border="1"><tr><td>23</td><td colspan="3">Redundant bits</td><td>N</td><td>0</td></tr></table>                                                                         | 23 | Redundant bits |         |                | N       | 0              |       |       |       |   |       |   |
| 23                                               | Redundant bits                                                                                                                                                                |    |                | N       | 0              |         |                |       |       |       |   |       |   |
| Mono 24-bit data mode, ORDER (I2S_CTL0[7]) = 1   | <table border="1"><tr><td>23</td><td colspan="3">N</td><td>0</td><td colspan="3">Redundant bits</td></tr></table>                                                             | 23 | N              |         |                | 0       | Redundant bits |       |       |       |   |       |   |
| 23                                               | N                                                                                                                                                                             |    |                | 0       | Redundant bits |         |                |       |       |       |   |       |   |
| Stereo 24-bit data mode, ORDER (I2S_CTL0[7]) = 0 | <table border="1"><tr><td>23</td><td colspan="3">Redundant bits</td><td>LEFT</td><td>0</td><td>N</td></tr></table>                                                            | 23 | Redundant bits |         |                | LEFT    | 0              | N     |       |       |   |       |   |
| 23                                               | Redundant bits                                                                                                                                                                |    |                | LEFT    | 0              | N       |                |       |       |       |   |       |   |
| Stereo 24-bit data mode, ORDER (I2S_CTL0[7]) = 1 | <table border="1"><tr><td>23</td><td colspan="3">Redundant bits</td><td>RIGHT</td><td>0</td><td>N+1</td></tr></table>                                                         | 23 | Redundant bits |         |                | RIGHT   | 0              | N+1   |       |       |   |       |   |
| 23                                               | Redundant bits                                                                                                                                                                |    |                | RIGHT   | 0              | N+1     |                |       |       |       |   |       |   |
| Mono 32-bit data mode                            | <table border="1"><tr><td>31</td><td colspan="3">N</td><td>0</td></tr></table>                                                                                                | 31 | N              |         |                | 0       |                |       |       |       |   |       |   |
| 31                                               | N                                                                                                                                                                             |    |                | 0       |                |         |                |       |       |       |   |       |   |
| Stereo 32-bit data mode                          | <table border="1"><tr><td>31</td><td colspan="3">LEFT</td><td>0</td><td>N</td></tr></table>                                                                                   | 31 | LEFT           |         |                | 0       | N              |       |       |       |   |       |   |
| 31                                               | LEFT                                                                                                                                                                          |    |                | 0       | N              |         |                |       |       |       |   |       |   |
|                                                  | <table border="1"><tr><td>31</td><td colspan="3">RIGHT</td><td>0</td><td>N+1</td></tr></table>                                                                                | 31 | RIGHT          |         |                | 0       | N+1            |       |       |       |   |       |   |
| 31                                               | RIGHT                                                                                                                                                                         |    |                | 0       | N+1            |         |                |       |       |       |   |       |   |

Figure 6.18-18 FIFO Contents for Various 2-channel Audio Modes

In 4-channel TDM PCM data format, the bit-width of audio data in a channel block can be 16, 24, or 32 bits. The memory arrangements of audio data for various settings are shown in Figure 6.18-19.

|                                                  |                |    |                |     |                |
|--------------------------------------------------|----------------|----|----------------|-----|----------------|
| Mono 16-bit data mode                            |                |    |                |     |                |
| 15                                               | N+1            | 0  | 15             | N   | 0              |
| Stereo 16-bit data mode, ORDER (I2S_CTL0[7]) = 0 |                |    |                |     |                |
| 15                                               | CH0            | 0  | 15             | CH1 | 0              |
| 15                                               | CH2            | 0  | 15             | CH3 | 0              |
| Stereo 16-bit data mode, ORDER (I2S_CTL0[7]) = 1 |                |    |                |     |                |
| 15                                               | CH1            | 0  | 15             | CH0 | 0              |
| 15                                               | CH3            | 0  | 15             | CH2 | 0              |
| Mono 24-bit data mode, ORDER (I2S_CTL0[7]) = 0   |                |    |                |     |                |
| 23                                               | Redundant bits | 23 | N              | 0   | Redundant bits |
| Mono 24-bit data mode, ORDER (I2S_CTL0[7]) = 1   |                |    |                |     |                |
| 23                                               | N              | 0  | Redundant bits |     |                |
| Stereo 24-bit data mode, ORDER (I2S_CTL0[7]) = 0 |                |    |                |     |                |
| 23                                               | Redundant bits | 23 | CH0            | 0   | N              |
| 23                                               | Redundant bits | 23 | CH1            | 0   | N+1            |
| 23                                               | Redundant bits | 23 | CH2            | 0   | N+2            |
| 23                                               | Redundant bits | 23 | CH3            | 0   | N+3            |
| Stereo 24-bit data mode, ORDER (I2S_CTL0[7]) = 1 |                |    |                |     |                |
| 23                                               | CH0            | 0  | Redundant bits | N   |                |
| 23                                               | CH1            | 0  | Redundant bits | N+1 |                |
| 23                                               | CH2            | 0  | Redundant bits | N+2 |                |
| 23                                               | CH3            | 0  | Redundant bits | N+3 |                |
| Mono 32-bit data mode                            |                |    |                |     |                |
| 31                                               | N              | 0  |                |     |                |
| Stereo 32-bit data mode                          |                |    |                |     |                |
| 31                                               | CH0            | 0  | N              |     |                |
| 31                                               | CH1            | 0  | N+1            |     |                |
| 31                                               | CH2            | 0  | N+2            |     |                |
| 31                                               | CH3            | 0  | N+3            |     |                |

Figure 6.18-19 FIFO Contents for Various 4-channel Audio Modes

In 6-channel TDM PCM data format, the bit-width of audio data in a channel block can be 16, 24, or 32

bits. The memory arrangements of audio data for various settings are shown Figure 6.18-20. In 16-bit audio data transmission, ORDER (I2S\_CTL0[7]) can be used to swap the audio data of even and odd channels which are stored in transmitting and receiving FIFO. In 24-bit audio data transmission, ORDER (I2S\_CTL0[7]) can be also used to select the left-alignment or right-alignment formula of audio data which is stored in 32-bit FIFO entries.

The FIFO content of 8-channel TDM PCM data format is similar to 6-channel and it can be analogized easily.

|                                                  |     |   |                |
|--------------------------------------------------|-----|---|----------------|
| Mono 16-bit data mode                            |     |   |                |
| 15                                               | N+1 | 0 | 15             |
| N                                                |     |   |                |
| 0                                                |     |   |                |
| Stereo 16-bit data mode, ORDER (I2S_CTL0[7]) = 0 |     |   |                |
| 15                                               | CH0 | 0 | 15             |
| 15                                               | CH2 | 0 | 15             |
| 15                                               | CH4 | 0 | 15             |
| CH1                                              |     |   | CH0            |
| 0                                                |     |   | 0              |
| CH3                                              |     |   | CH2            |
| 0                                                |     |   | 0              |
| CH5                                              |     |   | CH4            |
| 0                                                |     |   | 0              |
| Stereo 16-bit data mode, ORDER (I2S_CTL0[7]) = 1 |     |   |                |
| 15                                               | CH1 | 0 | 15             |
| 15                                               | CH3 | 0 | 15             |
| 15                                               | CH5 | 0 | 15             |
| CH0                                              |     |   | CH0            |
| 0                                                |     |   | 0              |
| CH2                                              |     |   | CH2            |
| 0                                                |     |   | 0              |
| CH4                                              |     |   | CH4            |
| 0                                                |     |   | 0              |
| Mono 24-bit data mode, ORDER (I2S_CTL0[7]) = 0   |     |   |                |
| Redundant bits                                   | 23  | N | 0              |
|                                                  |     |   |                |
| Mono 24-bit data mode, ORDER (I2S_CTL0[7]) = 1   |     |   |                |
| 23                                               | N   | 0 | Redundant bits |
|                                                  |     |   |                |

Figure 6.18-20 FIFO Contents for Various 6-channel Audio Modes (Part-1)



Figure 6.18-21 FIFO Contents for Various 6-channel Audio Modes (Part-2)

### 6.18.6 Register Map

R: Read only, W: Write only, R/W: Both read and write

| Register                    | Offset      | R/W | Description                                | Reset Value |
|-----------------------------|-------------|-----|--------------------------------------------|-------------|
| <b>I2S Base Address</b>     |             |     |                                            |             |
| <b>I2S_BA = 0x4004_8000</b> |             |     |                                            |             |
| <b>I2S_CTL0</b>             | I2S_BA+0x00 | R/W | I <sup>2</sup> S Control Register 0        | 0x0000_0000 |
| <b>I2S_CTL1</b>             | I2S_BA+0x20 | R/W | I <sup>2</sup> S Control Register 1        | 0x0000_0000 |
| <b>I2S_CLKDIV</b>           | I2S_BA+0x04 | R/W | I <sup>2</sup> S Clock Divider Register    | 0x0000_0000 |
| <b>I2S_IEN</b>              | I2S_BA+0x08 | R/W | I <sup>2</sup> S Interrupt Enable Register | 0x0000_0000 |
| <b>I2S_STATUS0</b>          | I2S_BA+0x0C | R/W | I <sup>2</sup> S Status Register 0         | 0x0014_1038 |
| <b>I2S_STATUS1</b>          | I2S_BA+0x24 | R/W | I <sup>2</sup> S Status Register 1         | 0x0000_0000 |
| <b>I2S_TXFIFO</b>           | I2S_BA+0x10 | W   | I <sup>2</sup> S Transmit FIFO Register    | 0x0000_0000 |
| <b>I2S_RXFIFO</b>           | I2S_BA+0x14 | R   | I <sup>2</sup> S Receive FIFO Register     | 0x0000_0000 |

### 6.18.7 Register Description

#### I<sup>2</sup>S Control Register 0 (I2S\_CTL0)

| Register | Offset      | R/W | Description            |  |  |  | Reset Value |
|----------|-------------|-----|------------------------|--|--|--|-------------|
| I2S_CTL0 | I2S_BA+0x00 | R/W | I2S Control Register 0 |  |  |  | 0x0000_0000 |

|          |          |          |          |         |         |          |       |
|----------|----------|----------|----------|---------|---------|----------|-------|
| 31       | 30       | 29       | 28       | 27      | 26      | 25       | 24    |
| TDMCHNUM |          | CHWIDTH  |          | PCMSYNC | FORMAT  |          |       |
| 23       | 22       | 21       | 20       | 19      | 18      | 17       | 16    |
| RXLCH    | Reserved | RXPDMAEN | TXPDMAEN | RXFBCLR | TXFBCLR | Reserved |       |
| 15       | 14       | 13       | 12       | 11      | 10      | 9        | 8     |
| MCLKEN   | Reserved |          |          |         |         |          | SLAVE |
| 7        | 6        | 5        | 4        | 3       | 2       | 1        | 0     |
| ORDER    | MONO     | DATWIDTH |          | MUTE    | RXEN    | TXEN     | I2SEN |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | <p><b>TDMCHNUM</b></p> <p><b>TDM Channel Number</b></p> <p>This bit fields are used to define the TDM channel number in one audio frame while PCM mode (FORMAT[2] = 1).</p> <p>00 = 2 channels in audio frame.<br/>01 = 4 channels in audio frame.<br/>10 = 6 channels in audio frame.<br/>11 = 8 channels in audio frame.</p>                                                                                                                                                                  |
| [29:28] | <p><b>CHWIDTH</b></p> <p><b>Channel Width</b></p> <p>This bit fields are used to define the length of audio channel. If CHWIDTH &lt; DATWIDTH, the hardware will set the real channel length as the bit-width of audio data which is defined by DATWIDTH.</p> <p>00 = The bit-width of each audio channel is 8-bit.<br/>01 = The bit-width of each audio channel is 16-bit.<br/>10 = The bit-width of each audio channel is 24-bit.<br/>11 = The bit-width of each audio channel is 32-bit.</p> |
| [27]    | <p><b>PCMSYNC</b></p> <p><b>PCM Synchronization Pulse Length Selection</b></p> <p>This bit field is used to select the high pulse length of frame synchronization signal in PCM protocol</p> <p>0 = One BCLK period.<br/>1 = One channel period.</p> <p><b>Note:</b> This bit is only available in master mode</p>                                                                                                                                                                              |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [26:24] | <b>FORMAT</b>   | <b>Data Format Selection</b><br>000 = I <sup>2</sup> S standard data format.<br>001 = I <sup>2</sup> S with MSB justified.<br>010 = I <sup>2</sup> S with LSB justified.<br>011 = Reserved.<br>100 = PCM standard data format.<br>101 = PCM with MSB justified.<br>110 = PCM with LSB justified.<br>111 = Reserved.                                                         |
| [23]    | <b>RXLCH</b>    | <b>Receive Left Channel Enable Bit</b><br>When monaural format is selected (MONO = 1), I <sup>2</sup> S will receive channel1 data if RXLCH is set to 0, and receive channel0 data if RXLCH is set to 1.<br>0 = Receive channel1 data in MONO mode.<br>1 = Receive channel0 data in MONO mode.                                                                              |
| [22]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                   |
| [21]    | <b>RXPDMAEN</b> | <b>Receive PDMA Enable Bit</b><br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.                                                                                                                                                                                                                                                                 |
| [20]    | <b>TXPDMAEN</b> | <b>Transmit PDMA Enable Bit</b><br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled.                                                                                                                                                                                                                                                              |
| [19]    | <b>RXFBCLR</b>  | <b>Receive FIFO Buffer Clear</b><br>0 = No Effect.<br>1 = Clear RX FIFO.<br><b>Note1:</b> Write 1 to clear receive FIFO, internal pointer is reset to FIFO start point, and RXCNT (I2S_STATUS1[20:16]) returns 0 and receive FIFO becomes empty.<br><b>Note2:</b> This bit is cleared by hardware automatically, read it return 0.                                          |
| [18]    | <b>TXFBCLR</b>  | <b>Transmit FIFO Buffer Clear</b><br>0 = No Effect.<br>1 = Clear TX FIFO.<br><b>Note1:</b> Write 1 to clear transmit FIFO, internal pointer is reset to FIFO start point, and TXCNT (I2S_STATUS1[12:8]) returns 0 and transmit FIFO becomes empty but data in transmit FIFO is not changed.<br><b>Note2:</b> This bit is clear by hardware automatically, read it return 0. |
| [17:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                   |
| [15]    | <b>MCLKEN</b>   | <b>Master Clock Enable Bit</b><br>If MCLKEN is set to 1, I <sup>2</sup> S controller will generate master clock on I2S_MCLK pin for external audio devices.<br>0 = Master clock Disabled.<br>1 = Master clock Enabled.                                                                                                                                                      |
| [14:9]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                   |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8]   | <b>SLAVE</b>    | <p><b>Slave Mode Enable Bit</b><br/>           0 = Master mode.<br/>           1 = Slave mode.</p> <p><b>Note:</b> I<sup>2</sup>S can operate as master or slave. For Master mode, I2S_BCLK and I2S_LRCLK pins are output mode and send out bit clock to Audio CODEC chip. In Slave mode, I2S_BCLK and I2S_LRCLK pins are input mode and I2S_BCLK and I2S_LRCLK signals are received from outer Audio CODEC chip.</p>                                                                                                                                                                                                                                                                                |
| [7]   | <b>ORDER</b>    | <p><b>Stereo Data Order in FIFO</b><br/>           In 8-bit/16-bit data width, this bit is used to select whether the even or odd channel data is stored in higher byte. In 24-bit data width, this is used to select the left/right alignment method of audio data which is stored in data memory consisted of 32-bit FIFO entries.</p> <p>0 = Even channel data at high byte in 8-bit/16-bit data width.<br/>           LSB of 24-bit audio data in each channel is aligned to right side in 32-bit FIFO entries.</p> <p>1 = Even channel data at low byte in 8-bit/16-bit data width.<br/>           MSB of 24-bit audio data in each channel is aligned to left side in 32-bit FIFO entries.</p> |
| [6]   | <b>MONO</b>     | <p><b>Monaural Data Control</b><br/>           0 = Data is stereo format.<br/>           1 = Data is monaural format.</p> <p><b>Note:</b> When chip records data, RXLCH (I2S_CTL0[23]) indicates which channel data will be saved if monaural format is selected.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [5:4] | <b>DATWIDTH</b> | <p><b>Data Width</b><br/>           This bit field is used to define the bit-width of data word in each audio channel</p> <p>00 = The bit-width of data word is 8-bit.<br/>           01 = The bit-width of data word is 16-bit.<br/>           10 = The bit-width of data word is 24-bit.<br/>           11 = The bit-width of data word is 32-bit.</p>                                                                                                                                                                                                                                                                                                                                             |
| [3]   | <b>MUTE</b>     | <p><b>Transmit Mute Enable Bit</b><br/>           0 = Transmit data is shifted from buffer.<br/>           1 = Send zero on transmit channel.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [2]   | <b>RXEN</b>     | <p><b>Receive Enable Bit</b><br/>           0 = Data receiving Disabled.<br/>           1 = Data receiving Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [1]   | <b>TXEN</b>     | <p><b>Transmit Enable Bit</b><br/>           0 = Data transmission Disabled.<br/>           1 = Data transmission Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [0]   | <b>I2SEN</b>    | <p><b>I<sup>2</sup>S Controller Enable Bit</b><br/>           0 = I<sup>2</sup>S controller Disabled.<br/>           1 = I<sup>2</sup>S controller Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**I<sup>2</sup>S Control Register 1 (I<sup>2</sup>S\_CTL1)**

| Register              | Offset                   | R/W | Description                         | Reset Value |
|-----------------------|--------------------------|-----|-------------------------------------|-------------|
| I <sup>2</sup> S_CTL1 | I <sup>2</sup> S_BA+0x20 | R/W | I <sup>2</sup> S Control Register 1 | 0x0000_0000 |

|          |         |         |         |         |         |         |         |
|----------|---------|---------|---------|---------|---------|---------|---------|
| 31       | 30      | 29      | 28      | 27      | 26      | 25      | 24      |
| Reserved |         |         |         |         |         | PB16ORD | PBWIDTH |
| 23       | 22      | 21      | 20      | 19      | 18      | 17      | 16      |
| Reserved |         |         |         | RXTH    |         |         |         |
| 15       | 14      | 13      | 12      | 11      | 10      | 9       | 8       |
| Reserved |         |         |         | TXTH    |         |         |         |
| 7        | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| CH7ZCEN  | CH6ZCEN | CH5ZCEN | CH4ZCEN | CH3ZCEN | CH2ZCEN | CH1ZCEN | CH0ZCEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [25]    | PB16ORD     | <p><b>FIFO Read/Write Order in 16-bit Width of Peripheral Bus</b></p> <p>When PBWIDTH = 1, the data FIFO will be increased or decreased by two peripheral bus access. This bit is used to select the order of FIFO access operations to meet the 32-bit transmitting/receiving FIFO entries.</p> <p>0 = Low 16-bit read/write access first.<br/>1 = High 16-bit read/write access first.</p> <p><b>Note:</b> This bit is available while PBWIDTH = 1.</p>                                                                                                                                            |
| [24]    | PBWIDTH     | <p><b>Peripheral Bus Data Width Selection</b></p> <p>This bit is used to choice the available data width of APB bus. It must be set to 1 while PDMA function is enable and it is set to 16-bit transmission mode</p> <p>0 = 32 bits data width.<br/>1 = 16 bits data width.</p> <p><b>Note1:</b> If PBWIDTH=1, the low 16 bits of 32-bit data bus are available.</p> <p><b>Note2:</b> If PBWIDTH=1, the transmitting FIFO level will be increased after two FIFO write operations.</p> <p><b>Note3:</b> If PBWIDTH=1, the receiving FIFO level will be decreased after two FIFO read operations.</p> |
| [23:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [19:16] | RXTH        | <p><b>Receive FIFO Threshold Level</b></p> <p>0000 = 1 data word in receive FIFO.<br/>0001 = 2 data words in receive FIFO.<br/>0010 = 3 data words in receive FIFO.<br/>....<br/>1110 = 15 data words in receive FIFO.<br/>1111 = 16 data words in receive FIFO.</p> <p><b>Note:</b> When received data word number in receive buffer is larger than threshold level then RXTHIF (I<sup>2</sup>S_STATUS0[10]) flag is set.</p>                                                                                                                                                                       |

|         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:12] | Reserved       | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [11:8]  | <b>TXTH</b>    | <p><b>Transmit FIFO Threshold Level</b></p> <p>0000 = 0 data word in transmit FIFO.</p> <p>0001 = 1 data word in transmit FIFO.</p> <p>0010 = 2 data words in transmit FIFO.</p> <p>....</p> <p>1110 = 14 data words in transmit FIFO.</p> <p>1111 = 15 data words in transmit FIFO.</p> <p><b>Note:</b> If remain data word number in transmit FIFO less or equal to than threshold level then TXTHIF (I2S_STATUS0[18]) flag is set.</p>                                                                                 |
| [7]     | <b>CH7ZCEN</b> | <p><b>Channel7 Zero-cross Detect Enable Bit</b></p> <p>0 = channel7 zero-cross detect Disabled.</p> <p>1 = channel7 zero-cross detect Enabled.</p> <p><b>Note1:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x3.</p> <p><b>Note2:</b> If this bit is set to 1, when channel7 data sign bit change or next shift data bits are all 0 then CH7ZCIF (I2S_STATUS1[7]) flag is set to 1.</p> <p><b>Note3:</b> If CH7ZCIF flag is set to 1, the channel7 will be mute.</p>          |
| [6]     | <b>CH6ZCEN</b> | <p><b>Channel6 Zero-cross Detect Enable Bit</b></p> <p>0 = channel6 zero-cross detect Disabled.</p> <p>1 = channel6 zero-cross detect Enabled.</p> <p><b>Note1:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x3.</p> <p><b>Note2:</b> If this bit is set to 1, when channel6 data sign bit change or next shift data bits are all 0 then CH6ZCIF(I2S_STATUS1[6]) flag is set to 1.</p> <p><b>Note3:</b> If CH6ZCIF flag is set to 1, the channel6 will be mute.</p>           |
| [5]     | <b>CH5ZCEN</b> | <p><b>Channel5 Zero-cross Detect Enable Bit</b></p> <p>0 = channel5 zero-cross detect Disabled.</p> <p>1 = channel5 zero-cross detect Enabled.</p> <p><b>Note1:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x2, 0x3.</p> <p><b>Note2:</b> If this bit is set to 1, when channel5 data sign bit change or next shift data bits are all 0 then CH5ZCIF(I2S_STATUS1[5]) flag is set to 1.</p> <p><b>Note3:</b> If CH5ZCIF flag is set to 1, the channel5 will be mute.</p>      |
| [4]     | <b>CH4ZCEN</b> | <p><b>Channel4 Zero-cross Detect Enable Bit</b></p> <p>0 = channel4 zero-cross detect Disabled.</p> <p>1 = channel4 zero-cross detect Enabled.</p> <p><b>Note1:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x2, 0x3.</p> <p><b>Note2:</b> If this bit is set to 1, when channel4 data sign bit change or next shift data bits are all 0 then CH4ZCIF(I2S_STATUS1[4]) flag is set to 1.</p> <p><b>Note3:</b> If CH4ZCIF flag is set to 1, the channel4 will be mute.</p>      |
| [3]     | <b>CH3ZCEN</b> | <p><b>Channel3 Zero-cross Detect Enable Bit</b></p> <p>0 = channel3 zero-cross detect Disabled.</p> <p>1 = channel3 zero-cross detect Enabled.</p> <p><b>Note1:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x1, 0x2, 0x3.</p> <p><b>Note2:</b> If this bit is set to 1, when channel3 data sign bit change or next shift data bits are all 0 then CH3ZCIF(I2S_STATUS1[3]) flag is set to 1.</p> <p><b>Note3:</b> If CH3ZCIF flag is set to 1, the channel3 will be mute.</p> |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>CH2ZCEN</b> | <b>Channel2 Zero-cross Detect Enable Bit</b><br>0 = channel2 zero-cross detect Disabled.<br>1 = channel2 zero-cross detect Enabled.<br><b>Note1:</b> This bit is available while multi-channel PCM mode and TDMCHNUM(I2S_CTL0[31:30]) = 0x1, 0x2, 0x3.<br><b>Note2:</b> If this bit is set to 1, when channel2 data sign bit change or next shift data bits are all 0 then CH2ZCIF(I2S_STATUS1[2]) flag is set to 1.<br><b>Note3:</b> If CH2ZCIF flag is set to 1, the channel2 will be mute. |
| [1] | <b>CH1ZCEN</b> | <b>Channel1 Zero-cross Detect Enable Bit</b><br>0 = channel1 zero-cross detect Disabled.<br>1 = channel1 zero-cross detect Enabled.<br><b>Note1:</b> Channel1 also means right audio channel while I2S (FORMAT[2]=0) or 2-channel PCM mode.<br><b>Note2:</b> If this bit is set to 1, when channel1 data sign bit change or next shift data bits are all 0 then CH1ZCIF(I2S_STATUS1[1]) flag is set to 1.<br><b>Note3:</b> If CH1ZCIF flag is set to 1, the channel1 will be mute.            |
| [0] | <b>CH0ZCEN</b> | <b>Channel0 Zero-cross Detection Enable Bit</b><br>0 = channel0 zero-cross detect Disabled.<br>1 = channel0 zero-cross detect Enabled.<br><b>Note1:</b> Channel0 also means left audio channel while I2S (FORMAT[2]=0) or 2-channel PCM mode.<br><b>Note2:</b> If this bit is set to 1, when channel0 data sign bit change or next shift data bits are all 0 then CH0ZCIF(I2S_STATUS1[0]) flag is set to 1.<br><b>Note3:</b> If CH0ZCIF flag is set to 1, the channel0 will be mute.          |

**I<sup>2</sup>S Clock Divider (I<sup>2</sup>S\_CLKDIV)**

| Register                | Offset                   | R/W | Description                             | Reset Value |
|-------------------------|--------------------------|-----|-----------------------------------------|-------------|
| I <sup>2</sup> S_CLKDIV | I <sup>2</sup> S_BA+0x04 | R/W | I <sup>2</sup> S Clock Divider Register | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [17:8]  | <b>BCLKDIV</b>  | <p><b>Bit Clock Divider</b></p> <p>The I<sup>2</sup>S controller will generate bit clock in Master mode. Software can program these bit fields to generate sampling rate clock frequency.</p> <p><math>F_{BCLK} = F_{I2SCLK} / (2^{(BCLKDIV + 1)})</math>.</p> <p><b>Note:</b> <math>F_{BCLK}</math> is the frequency of BCLK and <math>F_{I2SCLK}</math> is the frequency of I<sup>2</sup>S_CLK</p>                                                                                                                                                                                                                                                                                                                                   |
| [7]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [6:0]   | <b>MCLKDIV</b>  | <p><b>Master Clock Divider</b></p> <p>If chip external crystal frequency is <math>(2 \times MCLKDIV) \times 256\text{fs}</math> then software can program these bits to generate 256fs clock frequency to audio codec chip. If MCLKDIV is set to 0, MCLK is the same as external clock input.</p> <p>For example, sampling rate is 24 kHz and chip external crystal clock is 12.288 MHz, set MCLKDIV = 1.</p> <p><math>F_{MCLK} = F_{I2SCLK} / (2 \times (MCLKDIV))</math> (When MCLKDIV is <math>\geq 1</math>).</p> <p><math>F_{MCLK} = F_{I2SCLK}</math> (When MCLKDIV is set to 0).</p> <p><b>Note:</b> <math>F_{MCLK}</math> is the frequency of MCLK, and <math>F_{I2SCLK}</math> is the frequency of the I<sup>2</sup>S_CLK</p> |

**I<sup>2</sup>S Interrupt Enable Register (I2S\_IEN)**

| Register | Offset      | R/W | Description                                | Reset Value |
|----------|-------------|-----|--------------------------------------------|-------------|
| I2S_IEN  | I2S_BA+0x08 | R/W | I <sup>2</sup> S Interrupt Enable Register | 0x0000_0000 |

|          |          |          |          |          |          |          |          |
|----------|----------|----------|----------|----------|----------|----------|----------|
| 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
| Reserved |          |          |          |          |          |          |          |
| 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| CH7ZCIEN | CH6ZCIEN | CH5ZCIEN | CH4ZCIEN | CH3ZCIEN | CH2ZCIEN | CH1ZCIEN | CH0ZCIEN |
| 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved |          |          |          |          | TXTHIEN  | TXOVFIEN | TXUDFIEN |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved |          |          |          |          | RXTHIEN  | RXOVFIEN | RXUDFIEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                    |
| [23]    | CH7ZCIEN    | <p><b>Channel7 Zero-cross Interrupt Enable Bit</b><br/>           0 = Interrupt Disabled.<br/>           1 = Interrupt Enabled.</p> <p><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel7 zero-cross</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x3.</p>      |
| [22]    | CH6ZCIEN    | <p><b>Channel6 Zero-cross Interrupt Enable Bit</b><br/>           0 = Interrupt Disabled.<br/>           1 = Interrupt Enabled.</p> <p><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel6 zero-cross</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x3.</p>      |
| [21]    | CH5ZCIEN    | <p><b>Channel5 Zero-cross Interrupt Enable Bit</b><br/>           0 = Interrupt Disabled.<br/>           1 = Interrupt Enabled.</p> <p><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel5 zero-cross</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x2, 0x3.</p> |
| [20]    | CH4ZCIEN    | <p><b>Channel4 Zero-cross Interrupt Enable Bit</b><br/>           0 = Interrupt Disabled.<br/>           1 = Interrupt Enabled.</p> <p><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel4 zero-cross</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x2, 0x3.</p> |

|         |                 |                                                                                                                                                                                                                                                                                                            |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19]    | <b>CH3ZCIEN</b> | <b>Channel3 Zero-cross Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel3 zero-cross<br><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x1, 0x2, 0x3. |
| [18]    | <b>CH2ZCIEN</b> | <b>Channel2 Zero-cross Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel2 zero-cross<br><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x1, 0x2, 0x3. |
| [17]    | <b>CH1ZCIEN</b> | <b>Channel1 Zero-cross Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel1 zero-cross<br><b>Note2:</b> Channel1 also means right audio channel while I2S (FORMAT[2]=0) or 2-channel PCM mode.             |
| [16]    | <b>CH0ZCIEN</b> | <b>Channel0 Zero-cross Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note1:</b> Interrupt occurs if this bit is set to 1 and channel0 zero-cross<br><b>Note2:</b> Channel0 also means left audio channel while I2S (FORMAT[2]=0) or 2-channel PCM mode.              |
| [15:11] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                  |
| [10]    | <b>TXTHIEN</b>  | <b>Transmit FIFO Threshold Level Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> Interrupt occurs if this bit is set to 1 and data words in transmit FIFO is less than or equal to TXTH (I2S_CTL1[11:8]).                                                    |
| [9]     | <b>TXOVFIEN</b> | <b>Transmit FIFO Overflow Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> Interrupt occurs if this bit is set to 1 and TXOVIF (I2S_STATUS0[17]) flag is set to 1                                                                                             |
| [8]     | <b>TXUDFIEN</b> | <b>Transmit FIFO Underflow Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> Interrupt occur if this bit is set to 1 and TXUDIF (I2S_STATUS0[16]) flag is set to 1.                                                                                            |
| [7:3]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                  |
| [2]     | <b>RXTHIEN</b>  | <b>Receive FIFO Threshold Level Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> When data word in receive FIFO is equal or higher than RXTH (I2S_CTL1[19:16]) and the RXTHIF (I2S_STATUS0[10]) bit is set to 1. If RXTHIEN bit is enabled, interrupt occur.  |

|     |          |                                                                                                                                                                                                                                                                      |
|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | RXOVFIEN | <b>Receive FIFO Overflow Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> Interrupt occurs if this bit is set to 1 and RXOVIF (I2S_STATUS0[9]) flag is set to 1                                                         |
| [0] | RXUDFIEN | <b>Receive FIFO Underflow Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> If software reads receive FIFO when it is empty then RXUDIF (I2S_STATUS0[8]) flag is set to 1. If RXUDFIEN bit is enabled, interrupt occurs. |

**I<sup>2</sup>S Status Register 0 (I<sup>2</sup>S\_STATUS0)**

| Register                 | Offset                   | R/W | Description                        | Reset Value |
|--------------------------|--------------------------|-----|------------------------------------|-------------|
| I <sup>2</sup> S_STATUS0 | I <sup>2</sup> S_BA+0x0C | R/W | I <sup>2</sup> S Status Register 0 | 0x0014_1038 |

|          |    |        |         |        |                       |                       |                     |
|----------|----|--------|---------|--------|-----------------------|-----------------------|---------------------|
| 31       | 30 | 29     | 28      | 27     | 26                    | 25                    | 24                  |
| Reserved |    |        |         |        |                       |                       |                     |
| 23       | 22 | 21     | 20      | 19     | 18                    | 17                    | 16                  |
| Reserved |    | TXBUSY | TXEMPTY | TXFULL | TXTHIF                | TXOVIF                | TXUDIF              |
| 15       | 14 | 13     | 12      | 11     | 10                    | 9                     | 8                   |
| Reserved |    |        | RXEMPTY | RXFULL | RXTHIF                | RXOVIF                | RXUDIF              |
| 7        | 6  | 5      | 4       | 3      | 2                     | 1                     | 0                   |
| Reserved |    | DATACH |         |        | I <sup>2</sup> STXINT | I <sup>2</sup> SRXINT | I <sup>2</sup> SINT |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [21]    | TXBUSY      | <p><b>Transmit Busy (Read Only)</b><br/>           0 = Transmit shift buffer is empty.<br/>           1 = Transmit shift buffer is busy.<br/> <b>Note:</b> This bit is cleared to 0 when all data in transmit FIFO and shift buffer is shifted out. And set to 1 when 1st data is load to shift buffer.</p>                                                                                                                                                                                                                                 |
| [20]    | TXEMPTY     | <p><b>Transmit FIFO Empty (Read Only)</b><br/>           This bit reflect data word number in transmit FIFO is 0<br/>           0 = Not empty.<br/>           1 = Empty.</p>                                                                                                                                                                                                                                                                                                                                                                |
| [19]    | TXFULL      | <p><b>Transmit FIFO Full (Read Only)</b><br/>           This bit reflect data word number in transmit FIFO is 16<br/>           0 = Not full.<br/>           1 = Full.</p>                                                                                                                                                                                                                                                                                                                                                                  |
| [18]    | TXTHIF      | <p><b>Transmit FIFO Threshold Interrupt Flag (Read Only)</b><br/>           0 = Data word(s) in FIFO is larger than threshold level.<br/>           1 = Data word(s) in FIFO is less than or equal to threshold level.<br/> <b>Note:</b> When data word(s) in transmit FIFO is less than or equal to threshold value set in TXTH (I<sup>2</sup>S_CTL1[11:8]) the TXTHIF bit becomes to 1. It keeps at 1 till TXCNT (I<sup>2</sup>S_STATUS1[12:8]) is larger than TXTH (I<sup>2</sup>S_CTL1[11:8]) after software write TXFIFO register.</p> |
| [17]    | TXOVIF      | <p><b>Transmit FIFO Overflow Interrupt Flag</b><br/>           0 = No overflow.<br/>           1 = Overflow.<br/> <b>Note1:</b> Write data to transmit FIFO when it is full and this bit set to 1<br/> <b>Note2:</b> Write 1 to clear this bit to 0.</p>                                                                                                                                                                                                                                                                                    |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]    | <b>TXUDIF</b>   | <b>Transmit FIFO Underflow Interrupt Flag</b><br>0 = No underflow.<br>1 = Underflow.<br><b>Note1:</b> This bit will be set to 1 when shift logic hardware read data from transmitting FIFO and the filling data level in transmitting FIFO is not enough for one audio frame.<br><b>Note2:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                                                                                                                                                               |
| [15:13] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [12]    | <b>RXEMPTY</b>  | <b>Receive FIFO Empty (Read Only)</b><br>0 = Not empty.<br>1 = Empty.<br><b>Note:</b> This bit reflects data words number in receive FIFO is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [11]    | <b>RXFULL</b>   | <b>Receive FIFO Full (Read Only)</b><br>0 = Not full.<br>1 = Full.<br><b>Note:</b> This bit reflects data words number in receive FIFO is 16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [10]    | <b>RXTHIF</b>   | <b>Receive FIFO Threshold Interrupt Flag (Read Only)</b><br>0 = Data word(s) in FIFO is less than or equal to threshold level.<br>1 = Data word(s) in FIFO is larger than threshold level.<br><b>Note:</b> When data word(s) in receive FIFO is larger than threshold value set in RXTH (I2S_CTL1[19:16]) the RXTHIF bit becomes to 1. It keeps at 1 till RXCNT (I2S_STATUS1[20:16]) is less than or equal to RXTH (I2S_CTL1[19:16]) after software read RXFIFO register.                                                                                                                                                                                    |
| [9]     | <b>RXOVIF</b>   | <b>Receive FIFO Overflow Interrupt Flag</b><br>0 = No overflow occur.<br>1 = Overflow occur.<br><b>Note1:</b> When receive FIFO is full and receive hardware attempt to write data into receive FIFO then this bit is set to 1, data in 1st buffer is overwritten.<br><b>Note2:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                                                                                                                                                                          |
| [8]     | <b>RXUDIF</b>   | <b>Receive FIFO Underflow Interrupt Flag</b><br>0 = No underflow occur.<br>1 = Underflow occur.<br><b>Note1:</b> When receive FIFO is empty, and software reads the receive FIFO again. This bit will be set to 1, and it indicates underflow situation occurs.<br><b>Note2:</b> Write 1 to clear this bit to 0                                                                                                                                                                                                                                                                                                                                              |
| [7:6]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [5:3]   | <b>DATACh</b>   | <b>Transmission Data Channel (Read Only)</b><br>This bit fields are used to indicate which audio channel is current transmit data belong.<br>000 = channel0 (means left channel while 2-channel I2S/PCM mode).<br>001 = channel1 (means right channel while 2-channel I2S/PCM mode).<br>010 = channel2 (available while 4-channel TDM PCM mode).<br>011 = channel3 (available while 4-channel TDM PCM mode).<br>100 = channel4 (available while 6-channel TDM PCM mode).<br>101 = channel5 (available while 6-channel TDM PCM mode).<br>110 = channel6 (available while 8-channel TDM PCM mode).<br>111 = channel7 (available while 8-channel TDM PCM mode). |

|     |          |                                                                                                                                                                                        |
|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | I2STXINT | <b>I<sup>2</sup>S Transmit Interrupt (Read Only)</b><br>0 = No transmit interrupt.<br>1 = Transmit interrupt.                                                                          |
| [1] | I2SRXINT | <b>I<sup>2</sup>S Receive Interrupt (Read Only)</b><br>0 = No receive interrupt.<br>1 = Receive interrupt.                                                                             |
| [0] | I2SINT   | <b>I<sup>2</sup>S Interrupt Flag (Read Only)</b><br>0 = No I <sup>2</sup> S interrupt.<br>1 = I <sup>2</sup> S interrupt.<br><b>Note:</b> It is wire-OR of I2STXINT and I2SRXINT bits. |

**I<sup>2</sup>S Status Register 1 (I<sup>2</sup>S\_STATUS1)**

| Register                 | Offset                   | R/W | Description                        | Reset Value |
|--------------------------|--------------------------|-----|------------------------------------|-------------|
| I <sup>2</sup> S_STATUS1 | I <sup>2</sup> S_BA+0x24 | R/W | I <sup>2</sup> S Status Register 1 | 0x0000_0000 |

|          |         |         |         |         |         |         |         |
|----------|---------|---------|---------|---------|---------|---------|---------|
| 31       | 30      | 29      | 28      | 27      | 26      | 25      | 24      |
| Reserved |         |         |         |         |         |         |         |
| 23       | 22      | 21      | 20      | 19      | 18      | 17      | 16      |
| Reserved |         |         | RXCNT   |         |         |         |         |
| 15       | 14      | 13      | 12      | 11      | 10      | 9       | 8       |
| Reserved |         |         | TXCNT   |         |         |         |         |
| 7        | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| CH7ZCIF  | CH6ZCIF | CH5ZCIF | CH4ZCIF | CH3ZCIF | CH2ZCIF | CH1ZCIF | CH0ZCIF |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                              |
| [20:16] | RXCNT       | <p><b>Receive FIFO Level (Read Only)</b></p> <p>These bits indicate the number of available entries in receive FIFO</p> <p>00000 = No data.<br/>     00001 = 1 word in receive FIFO.<br/>     00010 = 2 words in receive FIFO.<br/>     ....<br/>     01110 = 14 words in receive FIFO.<br/>     01111 = 15 words in receive FIFO.<br/>     10000 = 16 words in receive FIFO.<br/>     Others are reserved.</p>        |
| [15:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                              |
| [12:8]  | TXCNT       | <p><b>Transmit FIFO Level (Read Only)</b></p> <p>These bits indicate the number of available entries in transmit FIFO</p> <p>00000 = No data.<br/>     00001 = 1 word in transmit FIFO.<br/>     00010 = 2 words in transmit FIFO.<br/>     ....<br/>     01110 = 14 words in transmit FIFO.<br/>     01111 = 15 words in transmit FIFO.<br/>     10000 = 16 words in transmit FIFO.<br/>     Others are reserved.</p> |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | <b>CH7ZCIF</b> | <p><b>Channel7 Zero-cross Interrupt Flag</b></p> <p>It indicates channel7 next sample data sign bit is changed or all data bits are 0.</p> <p>0 = No zero-cross in channel7.</p> <p>1 = Channel7 zero-cross is detected.</p> <p><b>Note1:</b> Write 1 to clear this bit to 0.</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x3.</p>           |
| [6] | <b>CH6ZCIF</b> | <p><b>Channel6 Zero-cross Interrupt Flag</b></p> <p>It indicates channel6 next sample data sign bit is changed or all data bits are 0.</p> <p>0 = No zero-cross in channel6.</p> <p>1 = Channel6 zero-cross is detected.</p> <p><b>Note1:</b> Write 1 to clear this bit to 0.</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x3.</p>           |
| [5] | <b>CH5ZCIF</b> | <p><b>Channel5 Zero-cross Interrupt Flag</b></p> <p>It indicates channel5 next sample data sign bit is changed or all data bits are 0.</p> <p>0 = No zero-cross in channel5.</p> <p>1 = Channel5 zero-cross is detected.</p> <p><b>Note1:</b> Write 1 to clear this bit to 0.</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x2, 0x3.</p>      |
| [4] | <b>CH4ZCIF</b> | <p><b>Channel4 Zero-cross Interrupt Flag</b></p> <p>It indicates channel4 next sample data sign bit is changed or all data bits are 0.</p> <p>0 = No zero-cross in channel4.</p> <p>1 = Channel4 zero-cross is detected.</p> <p><b>Note1:</b> Write 1 to clear this bit to 0.</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x2, 0x3.</p>      |
| [3] | <b>CH3ZCIF</b> | <p><b>Channel3 Zero-cross Interrupt Flag</b></p> <p>It indicates channel3 next sample data sign bit is changed or all data bits are 0.</p> <p>0 = No zero-cross in channel3.</p> <p>1 = Channel3 zero-cross is detected.</p> <p><b>Note1:</b> Write 1 to clear this bit to 0.</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x1, 0x2, 0x3.</p> |
| [2] | <b>CH2ZCIF</b> | <p><b>Channel2 Zero-cross Interrupt Flag</b></p> <p>It indicates channel2 next sample data sign bit is changed or all data bits are 0.</p> <p>0 = No zero-cross in channel2.</p> <p>1 = Channel2 zero-cross is detected.</p> <p><b>Note1:</b> Write 1 to clear this bit to 0.</p> <p><b>Note2:</b> This bit is available while multi-channel PCM mode and TDMCHNUM (I2S_CTL0[31:30]) = 0x1, 0x2, 0x3.</p> |

|     |                |                                                                                                                                                                                                                                                                                                                                                                    |
|-----|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | <b>CH1ZCIF</b> | <b>Channel1 Zero-cross Interrupt Flag</b><br>It indicates channel1 next sample data sign bit is changed or all data bits are 0.<br>0 = No zero-cross in channel1.<br>1 = Channel1 zero-cross is detected.<br><b>Note1:</b> Write 1 to clear this bit to 0.<br><b>Note2:</b> Channel1 also means right audio channel while I2S (FORMAT[2]=0) or 2-channel PCM mode. |
| [0] | <b>CH0ZCIF</b> | <b>Channel0 Zero-cross Interrupt Flag</b><br>It indicates channel0 next sample data sign bit is changed or all data bits are 0.<br>0 = No zero-cross in channel0.<br>1 = Channel0 zero-cross is detected.<br><b>Note1:</b> Write 1 to clear this bit to 0.<br><b>Note2:</b> Channel0 also means left audio channel while I2S (FORMAT[2]=0) or 2-channel PCM mode.  |

**I<sup>2</sup>S Transmit FIFO (I2S\_TXFIFO)**

| Register   | Offset      | R/W | Description                             | Reset Value |
|------------|-------------|-----|-----------------------------------------|-------------|
| I2S_TXFIFO | I2S_BA+0x10 | W   | I <sup>2</sup> S Transmit FIFO Register | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TXFIFO      | <b>Transmit FIFO Bits</b><br>I <sup>2</sup> S contains 16 words (16x32 bits) data buffer for data transmit. Write data to this register to prepare data for transmit. The remaining word number is indicated by TXCNT (I2S_STATUS1[12:8]). |

**I<sup>2</sup>S Receive FIFO (I2S\_RXFIFO)**

| Register   | Offset      | R/W | Description                            |  |  |  | Reset Value |
|------------|-------------|-----|----------------------------------------|--|--|--|-------------|
| I2S_RXFIFO | I2S_BA+0x14 | R   | I <sup>2</sup> S Receive FIFO Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | RXFIFO      | <b>Receive FIFO Bits</b><br>I <sup>2</sup> S contains 16 words (16x32 bits) data buffer for data receive. Read this register to get data in FIFO. The remaining data word number is indicated by RXCNT (I2S_STATUS1[20:16]). |

## 6.19 Serial Peripheral Interface (SPI)

### 6.19.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 M480 series contains up to four sets of SPI controllers performing a serial-to-parallel conversion on data received from a peripheral device, and a parallel-to-serial conversion on data transmitted to a peripheral device. Each SPI controller can be configured as a master or a slave device and supports the PDMA function to access the data buffer. Each SPI controller also supports I<sup>2</sup>S mode to connect external audio CODEC.

### 6.19.2 Features

- SPI Mode
  - Up to four sets of SPI controllers
  - Supports Master or Slave mode operation
  - Master mode up to 100 MHz and Slave mode up to 100 MHz (when chip works at V<sub>DD</sub> = 2.7~3.6V)
  - 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<sup>2</sup>S Mode
  - Supports Master or Slave
  - Capable of handling 8-, 16-, 24- and 32-bit word sizes
  - Each 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<sup>2</sup>S and MSB justified data format
  - Supports two PDMA requests, one for transmitting and the other for receiving

|                         | QSPIx   | SPIx                                                          |
|-------------------------|---------|---------------------------------------------------------------|
| Dual/Quad I/O Mode      | V       | X                                                             |
| Two-bit Transfer Mode   | V       | X                                                             |
| FIFO Depth              | 8-level | SPI mode 8~16 bits data length: 8-level<br>Otherwise: 4-level |
| Slave Time-out Function | V       | X                                                             |
| Slave 3-Wired Mode      | V       | X                                                             |

|                       |   |   |
|-----------------------|---|---|
| I <sup>2</sup> S Mode | X | V |
|-----------------------|---|---|

### 6.19.3 Block Diagram



Figure 6.19-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~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~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.19.4 Basic Configuration

#### 6.19.4.1 SPI0 Basic Configuration

- Clock source Configuration
  - Select the source of SPI0 peripheral clock on SPI0SEL (CLK\_CLKSEL2[5:4]).

- Enable SPI0 peripheral clock in SPI0CKEN (CLK\_APBCLK0[13]).
- Reset Configuration
  - Reset SPI0 controller in SPI0RST (SYS\_IPRST1[13]).
- Pin Configuration

| Group | Pin Name     | GPIO               | MFP  |
|-------|--------------|--------------------|------|
| SPI0  | SPI0_CLK     | PA.2, PB.14, PD.2  | MFP4 |
|       |              | PF.8               | MFP5 |
|       | SPI0_I2SMCLK | PA.4, PC.14, PD.13 | MFP4 |
|       |              | PF.10              | MFP5 |
|       |              | PB.0               | MFP8 |
|       |              | PB.11              | MFP9 |
|       | SPI0_MISO    | PA.1, PB.13, PD.1  | MFP4 |
|       |              | PF.7               | MFP5 |
|       | SPI0_MOSI    | PA.0, PB.12, PD.0  | MFP4 |
|       |              | PF.6               | MFP5 |
|       | SPI0_SS      | PA.3, PB.15, PD.3  | MFP4 |
|       |              | PF.9               | MFP5 |

#### 6.19.4.2 SPI1 Basic Configuration

- Clock source Configuration
  - Select the source of SPI1 peripheral clock on SPI1SEL (CLK\_CLKSEL2[7:6]).
  - Enable SPI1 peripheral clock in SPI1CKEN (CLK\_APBCLK0[14]).
- Reset Configuration
  - Reset SPI1 controller in SPI1RST (SYS\_IPRST1[14]).
- Pin Configuration

| Group | Pin Name     | GPIO        | MFP  |
|-------|--------------|-------------|------|
| SPI1  | SPI1_CLK     | PH.6        | MFP3 |
|       |              | PA.7        | MFP4 |
|       |              | PB.3, PD.5  | MFP5 |
|       |              | PH.8        | MFP6 |
|       |              | PC.1        | MFP7 |
|       | SPI1_I2SMCLK | PH.3        | MFP3 |
|       |              | PA.5        | MFP4 |
|       |              | PB.1, PD.13 | MFP5 |
|       |              | PH.10       | MFP6 |
|       |              | PC.4        | MFP7 |

|      |           |            |      |
|------|-----------|------------|------|
| SPI1 | SPI1_MISO | PH.4       | MFP3 |
|      |           | PC.7       | MFP4 |
|      |           | PB.5, PD.7 | MFP5 |
|      |           | PE.1       | MFP6 |
|      |           | PC.3       | MFP7 |
|      | SPI1_MOSI | PH.5       | MFP3 |
|      |           | PC.6       | MFP4 |
|      |           | PB.4, PD.6 | MFP5 |
|      |           | PE.0       | MFP6 |
|      |           | PC.2       | MFP7 |
|      | SPI1_SS   | PH.7       | MFP3 |
|      |           | PA.6       | MFP4 |
|      |           | PB.2, PD.4 | MFP5 |
|      |           | PH.9       | MFP6 |
|      |           | PC.0       | MFP7 |

#### 6.19.4.3 SPI2 Basic Configuration

- Clock source Configuration
  - Select the source of SPI2 peripheral clock on SPI2SEL (CLK\_CLKSEL2[11:10]).
  - Enable SPI2 peripheral clock in SPI2CKEN (CLK\_APBCLK0[15]).
- Reset Configuration
  - Reset SPI2 controller in SPI2RST (SYS\_IPRST1[15]).
- Pin Configuration

| Group | Pin Name     | GPIO         | MFP  |
|-------|--------------|--------------|------|
| SPI2  | SPI2_CLK     | PG.3         | MFP3 |
|       |              | PA.10        | MFP4 |
|       |              | PA.13, PE.8  | MFP5 |
|       | SPI2_I2SMCLK | PG.1         | MFP3 |
|       |              | PC.13        | MFP4 |
|       |              | PE.12        | MFP5 |
|       | SPI2_MISO    | PG.4         | MFP3 |
|       |              | PA.9         | MFP4 |
|       |              | PA.14, PE.9  | MFP5 |
|       | SPI2_MOSI    | PF.11        | MFP3 |
|       |              | PA.8         | MFP4 |
|       |              | PA.15, PE.10 | MFP5 |

|  |         |              |      |
|--|---------|--------------|------|
|  | SPI2_SS | PG.2         | MFP3 |
|  |         | PA.11        | MFP4 |
|  |         | PA.12, PE.11 | MFP5 |

#### 6.19.4.4 SPI3 Basic Configuration

- Clock source Configuration
  - Select the source of SPI3 peripheral clock on SPI3SEL (CLK\_CLKSEL2[13:12]).
  - Enable SPI3 peripheral clock in SPI3CKEN (CLK\_APBCLK1[6]).
- Reset Configuration
  - Reset SPI3 controller in SPI3RST (SYS\_IPRST2[6]).
- Pin configuration

| Group | Pin Name     | GPIO  | MFP   |
|-------|--------------|-------|-------|
| SPI3  | SPI3_CLK     | PG.6  | MFP3  |
|       |              | PE.4  | MFP5  |
|       |              | PC.10 | MFP6  |
|       |              | PB.11 | MFP11 |
|       | SPI3_I2SMCLK | PD.14 | MFP3  |
|       |              | PE.6  | MFP5  |
|       |              | PB.1  | MFP6  |
|       | SPI3_MISO    | PG.7  | MFP3  |
|       |              | PE.3  | MFP5  |
|       |              | PC.12 | MFP6  |
|       |              | PB.9  | MFP11 |
|       | SPI3_MOSI    | PG.8  | MFP3  |
|       |              | PE.2  | MFP5  |
|       |              | PC.11 | MFP6  |
|       |              | PB.8  | MFP11 |
|       | SPI3_SS      | PG.5  | MFP3  |
|       |              | PE.5  | MFP5  |
|       |              | PC.9  | MFP6  |
|       |              | PB.10 | MFP11 |

SPI/I<sup>2</sup>S (SPI0~SPI3) Interface Controller Pin description is shown as follows:

| Pin      | SPI Mode                | I <sup>2</sup> S Mode                                                      |
|----------|-------------------------|----------------------------------------------------------------------------|
| SPIx_SS  | SPI slave selection pin | I <sup>2</sup> S left/right channel synchronization clock pin (I2Sx_LRCLK) |
| SPIx_CLK | SPI clock pin           | I <sup>2</sup> S bit clock pin (I2Sx_BCLK)                                 |

|              |                                      |                                            |
|--------------|--------------------------------------|--------------------------------------------|
| SPIx_MISO    | SPI master input or slave output pin | I <sup>2</sup> S data input pin (I2Sx_DI)  |
| SPIx_MOSI    | SPI master output or slave input pin | I <sup>2</sup> S data output pin (I2Sx_DO) |
| SPIx_I2SMCLK | Not available                        | I <sup>2</sup> S Master clock output pin   |

Table 6.19-1 SPI/I<sup>2</sup>S Interface Controller Pin Description (SPI0~SPI3)

## 6.19.5 Functional Description

### 6.19.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.19-2 SPI Peripheral Clock

In Master mode, the frequency of the SPI bus clock is equal to the peripheral clock rate. In general, the SPI bus clock is denoted as SPI clock. In Slave mode, the SPI bus clock is provided by a master device. The frequency of SPI peripheral clock cannot be faster than the system clock rate regardless of Master or Slave mode. If the clock source of peripheral clock is not system clock, the frequency of SPI peripheral clock shall be slower than the system clock frequency regardless of Master or Slave mode.

In I<sup>2</sup>S mode, the peripheral clock rate is equal to I<sup>2</sup>S bit clock rate determined by SPIx\_I2SCLK 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.19-3 SPI Full-Duplex Master Mode Application Block Diagram



Figure 6.19-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 SPI<sub>x</sub>\_SS. In Slave mode, the off-chip master device drives the slave selection signal from the SPI<sub>x</sub>\_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 (SPI<sub>x</sub>\_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 (SPI<sub>x</sub>\_CTL[3]) defines the SPI clock idle state. If CLKPOL = 1, the output SPI clock is idle at high state; if CLKPOL = 0, it is idle at low state.

TXNEG (SPI<sub>x</sub>\_CTL[2]) defines the data transmitted out either on negative edge or on positive edge of SPI clock. RXNEG (SPI<sub>x</sub>\_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 (SPI<sub>x</sub>\_CTL[12:8]) and can be configured up

to 32-bit length in a transaction word for transmitting and receiving.

When SPI controller finishes a transaction, i.e. receives or transmits a specific count of bits defined in DWIDTH (SPIx\_CTL[12:8]), the unit transfer interrupt flag will be set to 1.



Figure 6.19-5 32-bit in One Transaction

#### LSB/MSB First

LSB (SPIx\_CTL[13]) defines the bit transfer sequence in a transaction. If the LSB (SPIx\_CTL[13]) is set to 1, the transfer sequence is LSB first. The bit 0 will be transferred firstly. If the LSB (SPIx\_CTL[13]) is cleared to 0, the transfer sequence is MSB first.

#### Suspend Interval

SUSPITV (SPIx\_CTL[7:4]) provides a configurable suspend interval, 0.5 ~ 15.5 SPI clock periods, between two successive transaction words in Master mode. The definition of the suspend interval is the interval between the last clock edge of the preceding transaction word and the first clock edge of the following transaction word. The default value of SUSPITV is 0x3 (3.5 SPI clock cycles).

##### 6.19.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.19-6 Automatic Slave Selection (SSACTPOL = 0, SUSPITV &gt; 0x2)



Figure 6.19-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV &lt; 0x3)

#### 6.19.5.3 Byte Reorder and Suspend Function

When the transfer is set as MSB first (LSB = 0) and the REORDER (SPIx\_CTL[19]) is set to 1, the data stored in the TX buffer and RX buffer will be rearranged in the order as [Byte0, Byte1, Byte2, Byte3] in 32-bit transfer (DWIDTH = 0). The sequence of transmitted/received data will be Byte0, Byte1, Byte2, and then Byte3. If the DWIDTH is set as 24-bit transfer mode, the data in TX buffer and RX buffer will be rearranged as [unknown byte, Byte0, Byte1, Byte2]. The SPI controller will transmit/receive data with the sequence of Byte0, Byte1 and then Byte2. Each byte will be transmitted/received with MSB first. The rule of 16-bit mode is the same as above. Byte Reorder function is only available when DWIDTH is configured as 16, 24, and 32 bits.



Figure 6.19-8 Byte Reorder Function

In Master mode, if REORDER (SPIx\_CTL[19]) is set to 1, a suspend interval of 0.5 ~ 15.5 SPI clock periods will be inserted by hardware between two successive bytes in a transaction word. The suspend interval is configured in SUSPITV (SPIx\_CTL[7:4]).



Figure 6.19-9 Timing Waveform for Byte Suspend

#### 6.19.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.19-10 SPI Half-Duplex Master Mode Application Block Diagram



Figure 6.19-11 SPI Half-Duplex Slave Mode Application Block Diagram

#### 6.19.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. After enabling this mode, the output SPI bus clock will be sent out in 6 peripheral clock cycles. In this mode, the data which has been written into transmit FIFO will be loaded into transmit shift register and sent out.

#### 6.19.5.6 PDMA Transfer Function

SPI controller supports PDMA transfer function.

When TXPDMAEN (SPIx\_PDMACTL[0]) is set to 1, the controller will issue request to PDMA controller to start the PDMA transmission process automatically.

When RXPDMAEN (SPIx\_PDMACTL[1]) is set to 1, the controller will start the PDMA reception process. SPI controller will issue request to PDMA controller automatically when there is data in the RX FIFO buffer.

**Note:** SPI supports single request PDMA (Read/Write) only, burst request PDMA is not supported.

#### 6.19.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 set to 0 when the transmit FIFO is empty and the current transaction has done. Thus, the status of BUSY (SPIx\_STATUS[0]) should be checked by software to make sure whether the SPI is in idle or not.

The receive control logic will store the SPI input data into the receive FIFO buffer. There are FIFO related status bits, like RXEMPTY (SPIx\_STATUS[8]) and RXFULL (SPIx\_STATUS[9]), to indicate the current status of RX FIFO buffer.

The transmitting and receiving threshold can be configured by setting TXTH (SPIx\_FIFOCTL[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.19-12 FIFO Threshold Comparator

In Master mode, when the first datum is written to the SPIx\_TX register, the TXEMPTY flag (SPIx\_STATUS[16]) will be cleared to 0. The transmission will start after 1 APB clock cycles and 6 peripheral clock cycles. User can write the next data into SPIx\_TX register immediately. The SPI controller will insert a suspend interval between two successive transactions. The period of suspend interval is decided by the setting of SUSPITV (SPIx\_CTL[7:4]). If the SUSPITV (SPIx\_CTL[7:4]) equals 0, SPI controller can perform continuous transfer. User can write data into SPIx\_TX register as long as the TXFULL (SPIx\_STATUS[17]) is 0.

In the example 1 of Figure 6.19-13, it indicates the updated condition of TXEMPTY (SPIx\_STATUS[16]) and the relationship among the FIFO buffer, shift register and the skew buffer. The TXEMPTY (SPIx\_STATUS[16]) is set to 0 when the Data0 is written into the FIFO buffer. The Data0 will be loaded into the shift register by the core logic and the TXEMPTY (SPIx\_STATUS[16]) will be to 1. The Data0 in shift register will be shift into skew buffer by bit for transmission until the transfer is done.

In the Example 2, it indicates the updated condition of TXFULL (SPIx\_STATUS[17]) when there are 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.19-13 Transmit FIFO Buffer Example

The subsequent transactions will be triggered automatically if the transmitted data are updated in time. If the SPIx\_TX register does not be updated after all data transfer are done, the transfer will stop.

In Master mode, during receiving operation, the serial data are received from SPIx\_MISO pin and stored to receive FIFO buffer.

The received data (Data0's b0, b1, ...b31) is stored into skew buffer first according the serial clock (SPIx\_CLK) and then it is shift into the shift register bit by bit. The core logic will load the data in shift register into FIFO buffer when the received data bit count reach the value of DWIDTH (SPIx\_CTL[12:8]). The RXEMPTY (SPIx\_STATUS[8]) will be cleared to 0 while the receive FIFO buffer contains unread data (see the Example 1 of Receive FIFO Buffer Example). The received data can be read by software from SPIx\_RX register as long as the RXEMPTY (SPIx\_STATUS[8]) is 0. If the receive FIFO buffer contains 8 unread data, the RXFULL (SPIx\_STATUS[9]) will be set to 1 (see the Example 2 of Receive FIFO Buffer Example).



Figure 6.19-14 Receive FIFO Buffer Example

In Slave mode, during transmission operation, when data is written to the SPIx\_TX register by software, the data will be loaded into transmit FIFO buffer and the TXEMPTY (SPIx\_STATUS[16]) will be set to 0. The transmission will start when the slave device receives clock signal from master. Data can be written to SPIx\_TX register as long as the TXFULL (SPIx\_STATUS[17]) is 0. After all data have been drawn out by the SPI transmission logic unit and the SPIx\_TX register is not updated by software, the TXEMPTY (SPIx\_STATUS[16]) will be set to 1.

If there is no any data written to the SPIx\_TX register, the transmit underflow interrupt flag, TXUFIF (SPIx\_STATUS[19]) will be set to 1 when the slave selection signal is active. The output data will be held by TXUFPOL (SPIx\_FIFOCTL[6]) setting during this transfer until the slave selection signal goes to inactive state. When the transmit underflow event occurs, the slave under run interrupt flag, SLVURIF (SPIx\_STATUS[7]), will be set to 1 as SPIx\_SS goes to inactive state.



Figure 6.19-15 TX Underflow Event and Slave Under Run Event

In Slave mode, during receiving operation, the serial data is received from SPIx\_MOSI pin and stored to SPIx\_RX register. The reception mechanism is similar to Master mode reception operation. If the receive FIFO buffer contains 4 unread data, the RXFULL (SPIx\_STATUS[9]) will be set to 1 and the

RXOVIF (SPIx\_STATUS[11]) will be set to 1 if there is more serial data received from SPIx\_MOSI and follow-up data will be dropped (refer to the Receive FIFO Buffer Example figure). If the receive bit count mismatch with the DWIDTH (SPIx\_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (SPIx\_STATUS[6]) will be set to 1.



Figure 6.19-16 Slave Mode Bit Count Error

A receive time-out function is built-in in this controller. When the receive FIFO is not empty and no read operation in receive FIFO over 64 SPI peripheral clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode, the receive time-out occurs and the RXTOIF (SPIx\_STATUS[12]) will be set to 1. When the receive FIFO is read by user, the time-out status will be cleared automatically.

#### 6.19.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 SSINAIFEN (SPIx\_SSCTL[13]) or SSACTIEN (SPIx\_SSCTL[12]), are set to 1.

- Slave bit count error interrupt

In Slave mode, if the transmit/receive bit count mismatch with the DWIDTH (SPIx\_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (SPIx\_STATUS[6]) will be set to 1. The uncompleted transaction will be dropped from TX and RX shift registers. The SPI controller will issue an interrupt if the SLVBEIEN (SPIx\_SSCTL[8]) is set to 1.

**Note:** If the slave selection signal is active but there is no any serial clock input, the SLVBEIF (SPIx\_STATUS[6]) will be set to 1 when the slave selection signal goes to inactive state.

- TX underflow interrupt

In SPI Slave mode, if there is no any data is written to the SPIx\_TX register, the TXUFIF (SPIx\_STATUS[19]) will be set to 1 when the slave selection signal is active. The SPI controller will issue a TX underflow interrupt if the TXUFIEN (SPIx\_FIFOCTL[7]) is set to

## 1.

**Note:** If underflow event occurs in SPI Slave mode, there are two conditions which make SPI Slave mode return to idle state and then goes for next transfer: (1) set TXRST to 1 (2) slave select signal is changed to inactive state.

- Slave TX 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, the RXFULL (SPIx\_STATUS[9]) will be set to 1 and the RXOVIF (SPIx\_STATUS[11]) will be set to 1 if there is more serial data is received from SPI bus and follow-up data will be dropped. The SPI controller will issue an interrupt if the RXOVIEN (SPIx\_FIFOCTL[5]) is set to 1.

- Receive FIFO time-out interrupt

If there is a received data in the FIFO buffer and it is not read by software over 64 SPI peripheral clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode, it will send a RX 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.19.5.9 I<sup>2</sup>S Mode

The SPI0~SPI3 controllers support I<sup>2</sup>S mode with PCM mode A, PCM mode B, MSB justified and I<sup>2</sup>S data format. The bit count of an audio channel is determined by WDWIDTH (SPIx\_I2SCTL[5:4]). The transfer sequence is always first from the most significant bit, MSB. Data are read on rising clock edge and are driven on falling clock edge.

In I<sup>2</sup>S data format, the MSB is sent and latched on the second clock of an audio channel. The I2Sx\_LRCLK signal indicates which audio channel is in transferring.



Figure 6.19-17 I<sup>2</sup>S Data Format Timing Diagram

In MSB justified data format, the MSB is sent and latched on the first clock of an audio channel.



Figure 6.19-18 MSB Justified Data Format Timing Diagram

The I2Sx\_LRCLK signal also supports PCM mode A and PCM mode B. The I2Sx\_LRCLK signal in PCM mode indicates the beginning of an audio frame.



Figure 6.19-19 PCM Mode A Timing Diagram



Figure 6.19-20 PCM Mode B Timing Diagram

6.19.5.10 I<sup>2</sup>S Mode FIFO Operation

Mono 8-bit data mode

|   |     |   |   |     |   |   |     |   |   |   |   |
|---|-----|---|---|-----|---|---|-----|---|---|---|---|
| 7 | N+3 | 0 | 7 | N+2 | 0 | 7 | N+1 | 0 | 7 | N | 0 |
|---|-----|---|---|-----|---|---|-----|---|---|---|---|

Stereo 8-bit data mode, ORDER (SPIx\_I2SCTL[7]) = 0

|   |        |   |   |         |   |   |      |   |   |       |   |
|---|--------|---|---|---------|---|---|------|---|---|-------|---|
| 7 | LEFT+1 | 0 | 7 | RIGHT+1 | 0 | 7 | LEFT | 0 | 7 | RIGHT | 0 |
|---|--------|---|---|---------|---|---|------|---|---|-------|---|

Stereo 8-bit data mode, ORDER (SPIx\_I2SCTL[7]) = 1

|   |         |   |   |        |   |   |       |   |   |      |   |
|---|---------|---|---|--------|---|---|-------|---|---|------|---|
| 7 | RIGHT+1 | 0 | 7 | LEFT+1 | 0 | 7 | RIGHT | 0 | 7 | LEFT | 0 |
|---|---------|---|---|--------|---|---|-------|---|---|------|---|

Mono 16-bit data mode

|    |     |   |    |   |   |
|----|-----|---|----|---|---|
| 15 | N+1 | 0 | 15 | N | 0 |
|----|-----|---|----|---|---|

Stereo 16-bit data mode, ORDER (SPIx\_I2SCTL[7]) = 0

|    |      |   |    |       |   |
|----|------|---|----|-------|---|
| 15 | LEFT | 0 | 15 | RIGHT | 0 |
|----|------|---|----|-------|---|

Stereo 16-bit data mode, ORDER (SPIx\_I2SCTL[7]) = 1

|    |       |   |    |      |   |
|----|-------|---|----|------|---|
| 15 | RIGHT | 0 | 15 | LEFT | 0 |
|----|-------|---|----|------|---|

Mono 24-bit data mode

|    |   |   |
|----|---|---|
| 23 | N | 0 |
|----|---|---|

Stereo 24-bit data mode

|    |      |   |   |
|----|------|---|---|
| 23 | LEFT | 0 | N |
|----|------|---|---|

|    |       |   |     |
|----|-------|---|-----|
| 23 | RIGHT | 0 | N+1 |
|----|-------|---|-----|

Mono 32-bit data mode

|    |   |   |
|----|---|---|
| 31 | N | 0 |
|----|---|---|

Stereo 32-bit data mode

|    |      |   |   |
|----|------|---|---|
| 31 | LEFT | 0 | N |
|----|------|---|---|

|    |       |   |     |
|----|-------|---|-----|
| 31 | RIGHT | 0 | N+1 |
|----|-------|---|-----|

Figure 6.19-21 FIFO Contents for Various I<sup>2</sup>S Modes

### 6.19.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.19-22 SPI Timing in Master Mode



Figure 6.19-23 SPI Timing in Master Mode (Alternate Phase of SPIx\_CLK)



Figure 6.19-24 SPI Timing in Slave Mode

Figure 6.19-25 SPI Timing in Slave Mode (Alternate Phase of SPI<sub>x</sub>\_CLK)

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

- Uses 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] = 0x08).
  - 6) Set MSB transfer first by clearing LSB (SPIx\_CTL[13]) to 0.
4. Set SPIEN (SPIx\_CTL[0]) to 1 to enable the data transfer with the SPI interface.
5. If this SPI master attempts to transmit (write) one byte data to the off-chip slave device, write the byte data that will be transmitted into the SPIx\_TX register.
6. Waiting for SPI interrupt if the UNITIEN (SPIx\_CTL[17]) is set to 1, or just polling the unit transfer interrupt flag UNITIF (SPIx\_STATUS[1]).
7. Read out the received one byte data from SPIx\_RX register.
8. Go to 5) to continue another data transfer or set SS (SPIx\_SSCTL[0]) to 0 to inactivate the off-chip 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 (SPIx\_CTL[12:8] = 0x08).
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.19.8 Register Map

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

| Register                                         | Offset       | R/W | Description                                     | Reset Value |
|--------------------------------------------------|--------------|-----|-------------------------------------------------|-------------|
| <b>SPI Base Address:</b>                         |              |     |                                                 |             |
| <b>SPIx_BA = 0x4006_1000 + (0x0000_1000 * x)</b> |              |     |                                                 |             |
| <b>x=0, 1, 2, 3</b>                              |              |     |                                                 |             |
| <b>SPIx_CTL</b>                                  | SPIx_BA+0x00 | R/W | SPI Control Register                            | 0x0000_0034 |
| <b>SPIx_CLKDIV</b>                               | SPIx_BA+0x04 | R/W | SPI Clock Divider Register                      | 0x0000_0000 |
| <b>SPIx_SSCTL</b>                                | SPIx_BA+0x08 | R/W | SPI Slave Select Control Register               | 0x0000_0000 |
| <b>SPIx_PDMACTL</b>                              | SPIx_BA+0x0C | R/W | SPI PDMA Control Register                       | 0x0000_0000 |
| <b>SPIx_FIFOCTL</b>                              | SPIx_BA+0x10 | R/W | SPI FIFO Control Register                       | 0x2200_0000 |
| <b>SPIx_STATUS</b>                               | SPIx_BA+0x14 | R/W | SPI Status Register                             | 0x0005_0110 |
| <b>SPIx_TX</b>                                   | SPIx_BA+0x20 | W   | SPI Data Transmit Register                      | 0x0000_0000 |
| <b>SPIx_RX</b>                                   | SPIx_BA+0x30 | R   | SPI Data Receive Register                       | 0x0000_0000 |
| <b>SPIx_I2SCTL</b>                               | SPIx_BA+0x60 | R/W | I <sup>2</sup> S Control Register               | 0x0000_0000 |
| <b>SPIx_I2SCLK</b>                               | SPIx_BA+0x64 | R/W | I <sup>2</sup> S Clock Divider Control Register | 0x0000_0000 |
| <b>SPIx_I2SSSTS</b>                              | SPIx_BA+0x68 | R/W | I <sup>2</sup> S Status Register                | 0x0005_0100 |

### 6.19.9 Register Description

#### SPI Control Register (SPIx\_CTL)

| Register | Offset       | R/W | Description          |  |  |  | Reset Value |
|----------|--------------|-----|----------------------|--|--|--|-------------|
| SPIx_CTL | SPIx_BA+0x00 | R/W | SPI Control Register |  |  |  | 0x0000_0034 |

Note: Not supported in I<sup>2</sup>S mode.

|          |         |     |        |         |       |         |          |
|----------|---------|-----|--------|---------|-------|---------|----------|
| 31       | 30      | 29  | 28     | 27      | 26    | 25      | 24       |
| Reserved |         |     |        |         |       |         |          |
| 23       | 22      | 21  | 20     | 19      | 18    | 17      | 16       |
| Reserved |         |     | DATDIR | REORDER | SLAVE | UNITIEN | Reserved |
| 15       | 14      | 13  | 12     | 11      | 10    | 9       | 8        |
| RXONLY   | HALFDPX | LSB | DWIDTH |         |       |         |          |
| 7        | 6       | 5   | 4      | 3       | 2     | 1       | 0        |
| SUSPITV  |         |     |        | CLKPOL  | TXNEG | RXNEG   | SPIEN    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [20]    | DATDIR      | <b>Data Port Direction Control</b><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     | <b>Byte Reorder Function Enable Bit</b><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><b>Note:</b> Byte Reorder function is only available if DWIDTH is defined as 16, 24, and 32 bits. |
| [18]    | SLAVE       | <b>Slave Mode Control</b><br>0 = Master mode.<br>1 = Slave mode.                                                                                                                                                                                                                                                                                               |
| [17]    | UNITIEN     | <b>Unit Transfer Interrupt Enable Bit</b><br>0 = SPI unit transfer interrupt Disabled.<br>1 = SPI unit transfer interrupt Enabled.                                                                                                                                                                                                                             |
| [16]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [15]    | RXONLY      | <b>Receive-only Mode Enable Bit (Master Only)</b><br>This bit field is only available in Master mode. In receive-only mode, SPI Master will generate SPI bus clock continuously for receiving data bit from SPI slave device and assert the BUSY status.<br>0 = Receive-only mode Disabled.<br>1 = Receive-only mode Enabled.                                  |
| [14]    | HALFDPX     | <b>SPI Half-duplex Transfer Enable Bit</b><br>This bit is used to select full-duplex or half-duplex for SPI transfer. The bit field DATDIR                                                                                                                                                                                                                     |

|        |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                | (SPIx_CTL[20]) can be used to set the data direction in half-duplex transfer.<br>0 = SPI operates in full-duplex transfer.<br>1 = SPI operates in half-duplex transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [13]   | <b>LSB</b>     | <b>Send LSB First</b><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] | <b>DWIDTH</b>  | <b>Data Width</b><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 = 0x08 .... 8 bits.<br>DWIDTH = 0x09 .... 9 bits.<br>.....<br>DWIDTH = 0x1F .... 31 bits.<br>DWIDTH = 0x00 .... 32 bits.<br><b>Note:</b> 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]  | <b>SUSPITV</b> | <b>Suspend Interval (Master Only)</b><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 0x3. The period of the suspend interval is obtained according to the following equation.<br>$(\text{SUSPITV}[3:0] + 0.5) * \text{period of SPICLK clock cycle}$<br>Example:<br>SUSPITV = 0x0 .... 0.5 SPICLK clock cycle.<br>SUSPITV = 0x1 .... 1.5 SPICLK clock cycle.<br>.....<br>SUSPITV = 0xE .... 14.5 SPICLK clock cycle.<br>SUSPITV = 0xF .... 15.5 SPICLK clock cycle. |
| [3]    | <b>CLKPOL</b>  | <b>Clock Polarity</b><br>0 = SPI bus clock is idle low.<br>1 = SPI bus clock is idle high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [2]    | <b>TXNEG</b>   | <b>Transmit on Negative Edge</b><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]    | <b>RXNEG</b>   | <b>Receive on Negative Edge</b><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]    | <b>SPIEN</b>   | <b>SPI Transfer Control Enable Bit</b><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.<br>0 = Transfer control Disabled.<br>1 = Transfer control Enabled.<br><b>Note:</b> Before changing the configurations of SPIx_CTL, SPIx_CLKDIV, SPIx_SSCTL and SPIx_FIFOCNTL 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 |  |  |  |  | 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 |    |    |    |    |    |    | DIVIDER |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| DIVIDER  |    |    |    |    |    |    |         |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [8:0]  | DIVIDER     | <p><b>Clock Divider</b></p> <p>The value in this field is the frequency divider for generating the peripheral clock, <math>f_{spi\_eclk}</math>, and the SPI bus clock of SPI Master. The frequency is obtained according to the following equation.</p> $f_{spi\_eclk} = \frac{f_{spi\_clock\_src}}{(DIVIDER + 1)}$ <p>where</p> <p><math>f_{spi\_clock\_src}</math> is the peripheral clock source, which is defined in the clock control register, CLK_CLKSEL2.</p> <p><b>Note:</b> Not supported in I<sup>2</sup>S mode.</p> |

**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<sup>2</sup>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 | Reserved |          | SLVURIEN | SLVBEIEN |
| 7        | 6  | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved |    |          |          | AUTOSS   | SSACTPOL | Reserved | SS       |

| Bits    | Description |                                                                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [13]    | SSINAIEN    | <b>Slave Select Inactive Interrupt Enable Bit</b><br>0 = Slave select inactive interrupt Disabled.<br>1 = Slave select inactive interrupt Enabled.                                                                                                             |
| [12]    | SSACTIEN    | <b>Slave Select Active Interrupt Enable Bit</b><br>0 = Slave select active interrupt Disabled.<br>1 = Slave select active interrupt Enabled.                                                                                                                   |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [9]     | SLVURIEN    | <b>Slave Mode TX Under Run Interrupt Enable Bit</b><br>0 = Slave mode TX under run interrupt Disabled.<br>1 = Slave mode TX under run interrupt Enabled.                                                                                                       |
| [8]     | SLVBEIEN    | <b>Slave Mode Bit Count Error Interrupt Enable Bit</b><br>0 = Slave mode bit count error interrupt Disabled.<br>1 = Slave mode bit count error interrupt Enabled.                                                                                              |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [3]     | AUTOSS      | <b>Automatic Slave Selection Function Enable Bit (Master Only)</b><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    | <b>Slave Selection Active Polarity</b><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] | <b>SS</b> | <b>Slave Selection Control (Master Only)</b><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 driven to inactive state for the rest of the time. The active state of SPIx_SS is specified in SSACTPOL (SPIx_SSCTL[2]). |
|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**SPI PDMA Control Register (SPIx\_PDMACTL)**

| Register     | Offset       | R/W | Description               |  |  |  | Reset Value |
|--------------|--------------|-----|---------------------------|--|--|--|-------------|
| SPIx_PDMACTL | SPIx_BA+0x0C | R/W | SPI PDMA Control Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                  |
| [2]    | PDMARST     | <b>PDMA Reset</b><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    | <b>Receive PDMA Enable Bit</b><br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.                                                                                                                                                                                                                                                                |
| [0]    | TXPDMAEN    | <b>Transmit PDMA Enable Bit</b><br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled.<br><b>Note:</b> In SPI 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. |

**SPI FIFO Control Register (SPIx\_FIFOCTL)**

| Register     | Offset       | R/W | Description               |  |  |  | Reset Value |
|--------------|--------------|-----|---------------------------|--|--|--|-------------|
| SPIx_FIFOCTL | SPIx_BA+0x10 | R/W | SPI FIFO Control Register |  |  |  | 0x2200_0000 |

|          |         |         |         |          |         |         |          |
|----------|---------|---------|---------|----------|---------|---------|----------|
| 31       | 30      | 29      | 28      | 27       | 26      | 25      | 24       |
| Reserved | TXTH    |         |         | Reserved | RXTH    |         |          |
| 23       | 22      | 21      | 20      | 19       | 18      | 17      | 16       |
| Reserved |         |         |         |          |         |         |          |
| 15       | 14      | 13      | 12      | 11       | 10      | 9       | 8        |
| Reserved |         |         |         |          |         | TXFBCLR | RXFBCCLR |
| 7        | 6       | 5       | 4       | 3        | 2       | 1       | 0        |
| TXUFIEN  | TXUFPOL | RXOVIEN | RXTOIEN | TXTHIEN  | RXTHIEN | TXRST   | RXRST    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [30:28] | TXTH        | <b>Transmit FIFO Threshold</b><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        | <b>Receive FIFO Threshold</b><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~16 bits of data length.                             |
| [23:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [9]     | TXFBCLR     | <b>Transmit FIFO Buffer Clear</b><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><b>Note:</b> The TX shift register will not be cleared. |
| [8]     | RXFBCCLR    | <b>Receive FIFO Buffer Clear</b><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><b>Note:</b> The RX shift register will not be cleared.   |
| [7]     | TXUFIEN     | <b>TX Underflow Interrupt Enable Bit</b><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.<br>0 = Slave TX underflow interrupt Disabled.<br>1 = Slave TX underflow interrupt Enabled.                            |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | <b>TXUFFPOL</b> | <p><b>TX Underflow Data Polarity</b></p> <p>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.</p> <p><b>Note:</b></p> <ol style="list-style-type: none"> <li>1. The TX underflow event occurs if there is no any data in TX FIFO when the slave selection signal is active.</li> <li>2. This bit should be set as 0 in I<sup>2</sup>S mode.</li> <li>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.</li> </ol> |
| [5] | <b>RXOVIEN</b>  | <p><b>Receive FIFO Overrun Interrupt Enable Bit</b></p> <p>0 = Receive FIFO overrun interrupt Disabled.<br/>1 = Receive FIFO overrun interrupt Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [4] | <b>RXTOIEN</b>  | <p><b>Slave Receive Time-out Interrupt Enable Bit</b></p> <p>0 = Receive time-out interrupt Disabled.<br/>1 = Receive time-out interrupt Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [3] | <b>TXTHIEN</b>  | <p><b>Transmit FIFO Threshold Interrupt Enable Bit</b></p> <p>0 = TX FIFO threshold interrupt Disabled.<br/>1 = TX FIFO threshold interrupt Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [2] | <b>RXTHIEN</b>  | <p><b>Receive FIFO Threshold Interrupt Enable Bit</b></p> <p>0 = RX FIFO threshold interrupt Disabled.<br/>1 = RX FIFO threshold interrupt Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [1] | <b>TXRST</b>    | <p><b>Transmit Reset</b></p> <p>0 = 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.</p> <p><b>Note:</b> If TX underflow event occurs in SPI Slave mode, this bit can be used to make SPI return to idle state.</p>                                                                                                                                                                             |
| [0] | <b>RXRST</b>    | <p><b>Receive Reset</b></p> <p>0 = 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.</p>                                                                                                                                                                                                                                                                                                           |

**SPI Status Register (SPIx\_STATUS)**

| Register    | Offset       | R/W | Description         |  |  |  | Reset Value |
|-------------|--------------|-----|---------------------|--|--|--|-------------|
| SPIx_STATUS | SPIx_BA+0x14 | R/W | SPI Status Register |  |  |  | 0x0005_0110 |

**Note:** Not supported in I<sup>2</sup>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       | <b>Transmit FIFO Data Count (Read Only)</b><br>This bit field indicates the valid data count of transmit FIFO buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [27:24] | RXCNT       | <b>Receive FIFO Data Count (Read Only)</b><br>This bit field indicates the valid data count of receive FIFO buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [23]    | TXRXRST     | <b>TX or RX Reset Status (Read Only)</b><br>0 = The reset function of TXRST or RXRST is done.<br>1 = Doing the reset function of TXRST or RXRST.<br><b>Note:</b> 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      | <b>TX Underflow Interrupt Flag</b><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><b>Note 1:</b> This bit will be cleared by writing 1 to it.<br><b>Note 2:</b> 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      | <b>Transmit FIFO Threshold Interrupt Flag (Read Only)</b><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      | <b>Transmit FIFO Buffer Full Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 1 = Transmit FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [16]    | <b>TXEMPTY</b>  | <b>Transmit FIFO Buffer Empty Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not empty.<br>1 = Transmit FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                                              |
| [15]    | <b>SPIENSTS</b> | <b>SPI Enable Status (Read Only)</b><br>0 = SPI controller Disabled.<br>1 = SPI controller Enabled.<br><b>Note:</b> 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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [12]    | <b>RXTOIF</b>   | <b>Receive Time-out Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it.                                                    |
| [11]    | <b>RXOVIF</b>   | <b>Receive FIFO Overrun Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                        |
| [10]    | <b>RXTHIF</b>   | <b>Receive FIFO Threshold Interrupt Flag (Read Only)</b><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]     | <b>RXFULL</b>   | <b>Receive FIFO Buffer Full Indicator (Read Only)</b><br>0 = Receive FIFO buffer is not full.<br>1 = Receive FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                                                    |
| [8]     | <b>RXEMPTY</b>  | <b>Receive FIFO Buffer Empty Indicator (Read Only)</b><br>0 = Receive FIFO buffer is not empty.<br>1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                                                 |
| [7]     | <b>SLVURIF</b>  | <b>Slave Mode TX Under Run Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it.                                                                                                                                                                      |
| [6]     | <b>SLVBEIF</b>  | <b>Slave Mode Bit Count Error Interrupt Flag</b><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><b>Note:</b> 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]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | <b>SSLIN</b>   | <b>Slave Select Line Bus Status (Read Only)</b><br>0 = The slave select line status is 0.<br>1 = The slave select line status is 1.<br><b>Note:</b> This bit is only available in Slave mode. If SSACTPOL (SPIx_SSCTL[2]) is set 0, and the SSLIN is 1, the SPI slave select is in inactive status.                                                                                                                                                                                                                                                                                                                                                                 |
| [3] | <b>SSINAIF</b> | <b>Slave Select Inactive Interrupt Flag</b><br>0 = Slave select inactive interrupt was cleared or not occurred.<br>1 = Slave select inactive interrupt event occurred.<br><b>Note:</b> Only available in Slave mode. This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                   |
| [2] | <b>SSACTIF</b> | <b>Slave Select Active Interrupt Flag</b><br>0 = Slave select active interrupt was cleared or not occurred.<br>1 = Slave select active interrupt event occurred.<br><b>Note:</b> Only available in Slave mode. This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                         |
| [1] | <b>UNITIF</b>  | <b>Unit Transfer Interrupt Flag</b><br>0 = No transaction has been finished since this bit was cleared to 0.<br>1 = SPI controller has finished one unit transfer.<br><b>Note:</b> This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [0] | <b>BUSY</b>    | <b>Busy Status (Read Only)</b><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. SPIx_CTL[0] = 1 and TXEMPTY = 0.<br>b. For SPI Master mode, SPIx_CTL[0] = 1 and TXEMPTY = 1 but the current transaction is not finished yet.<br>c. For SPI Master mode, SPIx_CTL[0] = 1 and RXONLY = 1.<br>d. For SPI Slave mode, the SPIx_CTL[0] = 1 and there is serial clock input into the SPI core logic when slave select is active.<br>e. For SPI Slave mode, the SPIx_CTL[0] = 1 and the transmit buffer or transmit shift register is not empty even if the slave select is inactive. |

**SPI Data Transmit Register (SPIx\_TX)**

| Register | Offset       | R/W | Description                |  |  |  |  | Reset Value |
|----------|--------------|-----|----------------------------|--|--|--|--|-------------|
| SPIx_TX  | SPIx_BA+0x20 | W   | SPI Data Transmit Register |  |  |  |  | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TX          | <p><b>Data Transmit Register</b></p> <p>The data transmit registers pass through the transmitted data into the 4-level transmit FIFO buffers. The number of valid bits depends on the setting of DWIDTH (SPIx_CTL[12:8]) in SPI mode or WDWIDHT (SPIx_I2SCTL[5:4]) in I<sup>2</sup>S mode.</p> <p>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.</p> <p>In I<sup>2</sup>S mode, if WDWIDHT (SPIx_I2SCTL[5:4]) is set to 0x2, the data width of audio channel is 24-bit and corresponding to TX[23:0]. If WDWIDHT is set as 0x0, 0x1, or 0x3, all bits of this field are valid and referred to the data arrangement in I<sup>2</sup>S mode FIFO operation section</p> <p><b>Note:</b> In Master mode, SPI controller will start to transfer the SPI bus clock after 1 APB clock and 6 peripheral clock cycles after user writes to this register.</p> |

**SPI Data Receive Register (SPIx\_RX)**

| Register | Offset       | R/W | Description               |  |  |  |  | Reset Value |
|----------|--------------|-----|---------------------------|--|--|--|--|-------------|
| SPIx_RX  | SPIx_BA+0x30 | R   | SPI Data Receive Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | RX          | <p><b>Data Receive Register (Read Only)</b></p> <p>There are 4-level FIFO buffers in this controller. The data receive register holds the data received from SPI data input pin. If the RXEMPTY (SPIx_STATUS[8] or SPIx_I2SSTS[8]) is not set to 1, the receive FIFO buffers can be accessed through software by reading this register.</p> |

**I<sup>2</sup>S Control Register (SPIx\_I2SCTL)**

| Register    | Offset       | R/W | Description                       |  |  |  | Reset Value |
|-------------|--------------|-----|-----------------------------------|--|--|--|-------------|
| SPIx_I2SCTL | SPIx_BA+0x60 | R/W | I <sup>2</sup> S Control Register |  |  |  | 0x0000_0000 |

**Note:** Not supported in SPI mode.

|          |          |         |    |      |          |       |        |
|----------|----------|---------|----|------|----------|-------|--------|
| 31       | 30       | 29      | 28 | 27   | 26       | 25    | 24     |
| Reserved |          | FORMAT  |    |      | Reserved |       | LZCIEN |
| 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:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                   |
| [29:28] | FORMAT      | <b>Data Format Selection</b><br>00 = I <sup>2</sup> S data format.<br>01 = MSB justified data format.<br>10 = PCM mode A.<br>11 = PCM mode B.                                                                                                                                                                               |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                   |
| [25]    | LZCIEN      | <b>Left Channel Zero Cross Interrupt Enable Bit</b><br>Interrupt occurs if this bit is set to 1 and left channel zero cross event occurs.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                              |
| [24]    | RZCIEN      | <b>Right Channel Zero Cross Interrupt Enable Bit</b><br>Interrupt occurs if this bit is set to 1 and right channel zero cross event occurs.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                            |
| [23]    | RXLCH       | <b>Receive Left Channel Enable Bit</b><br>When monaural format is selected (MONO = 1), I <sup>2</sup> S controller will receive right channel data if RXLCH is set to 0, and receive left channel data if RXLCH is set to 1.<br>0 = Receive right channel data in Mono mode.<br>1 = Receive left channel data in Mono mode. |
| [22:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                   |

|        |          |                                                                                                                                                                                                                                                                                                                                                                               |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]   | LZCEN    | <b>Left Channel Zero Cross Detection Enable Bit</b><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    | <b>Right Channel Zero Cross Detection Enable Bit</b><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   | <b>Master Clock Enable Bit</b><br>If MCLKEN is set to 1, I <sup>2</sup> S controller will generate master clock on SPIx_I2SMCLK pin for external audio devices.<br>0 = Master clock Disabled.<br>1 = Master clock Enabled.                                                                                                                                                    |
| [14:9] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                     |
| [8]    | SLAVE    | <b>Slave Mode</b><br>I <sup>2</sup> 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.<br>0 = Master mode.<br>1 = Slave mode. |
| [7]    | ORDER    | <b>Stereo Data Order in FIFO</b><br>0 = Left channel data at high byte.<br>1 = Left channel data at low byte.                                                                                                                                                                                                                                                                 |
| [6]    | MONO     | <b>Monaural Data</b><br>0 = Data is stereo format.<br>1 = Data is monaural format.                                                                                                                                                                                                                                                                                            |
| [5:4]  | WDWIDTH  | <b>Word Width</b><br>00 = data size is 8-bit.<br>01 = data size is 16-bit.<br>10 = data size is 24-bit.<br>11 = data size is 32-bit.                                                                                                                                                                                                                                          |
| [3]    | MUTE     | <b>Transmit Mute Enable Bit</b><br>0 = Transmit data is shifted from buffer.<br>1 = Transmit channel zero.                                                                                                                                                                                                                                                                    |
| [2]    | RXEN     | <b>Receive Enable Bit</b><br>0 = Data receive Disabled.<br>1 = Data receive Enabled.                                                                                                                                                                                                                                                                                          |
| [1]    | TXEN     | <b>Transmit Enable Bit</b><br>0 = Data transmit Disabled.<br>1 = Data transmit Enabled.                                                                                                                                                                                                                                                                                       |

|     |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | I2SEN | <p><b>I<sup>2</sup>S Controller Enable Bit</b></p> <p>0 = I<sup>2</sup>S mode Disabled.<br/>1 = I<sup>2</sup>S mode Enabled.</p> <p><b>Note:</b></p> <ol style="list-style-type: none"><li>1. If enabling this bit, I2Sx_BCLK will start to output in Master mode.</li><li>2. Before changing the configurations of SPIx_I2SCTL, SPIx_I2SCLK, and SPIx_FIFOCCTL registers, user shall clear the I2SEN (SPIx_I2SCTL[0]) and confirm the I2SENSTS (SPIx_I2SSTS[15]) is 0.</li></ol> |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**I<sup>2</sup>S Clock Divider Control Register (SPIx\_I2SCLK)**

| Register    | Offset       | R/W | Description                                     | Reset Value |
|-------------|--------------|-----|-------------------------------------------------|-------------|
| SPIx_I2SCLK | SPIx_BA+0x64 | R/W | I <sup>2</sup> S Clock Divider Control Register | 0x0000_0000 |

**Note:** Not supported in SPI mode.

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [17:8]  | BCLKDIV     | <p><b>Bit Clock Divider</b></p> <p>The I<sup>2</sup>S controller will generate bit clock in Master mode. The clock frequency of bit clock , <math>f_{BCLK}</math>, is determined by the following expression:</p> $f_{BCLK} = \frac{f_{i2s\_clock\_src}}{2 \times (BCLKDIV + 1)}$ <p>where</p> <p><math>f_{i2s\_clock\_src}</math> is the frequency of I<sup>2</sup>S peripheral clock source, which is defined in the clock control register CLK_CLKSEL2.</p> <p>In I<sup>2</sup>S Slave mode, this field is used to define the frequency of peripheral clock and it's determined by <math>f_{i2s\_clock\_src} \div \left( \frac{BCLKDIV}{2} + 1 \right)</math>.</p> <p>The peripheral clock frequency in I<sup>2</sup>S Slave mode must be equal to or faster than 6 times of input bit clock.</p> |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [6:0]   | MCLKDIV     | <p><b>Master Clock Divider</b></p> <p>If MCLKEN is set to 1, I<sup>2</sup>S controller will generate master clock for external audio devices. The frequency of master clock, <math>f_{MCLK}</math>, is determined by the following expressions:</p> <p>If <math>MCLKDIV \geq 1</math>, <math>f_{MCLK} = \frac{f_{i2s\_clock\_src}}{2 \times MCLKDIV}</math></p> <p>If <math>MCLKDIV = 0</math>, <math>f_{MCLK} = f_{i2s\_clock\_src}</math></p> <p>where</p> <p><math>f_{i2s\_clock\_src}</math> is the frequency of I<sup>2</sup>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.</p>                                                                                                     |

**Note:** BCLKDIV should be set carefully because the peripheral clock frequency must be slower than or equal to system frequency.

**I<sup>2</sup>S Status Register (SPIx\_I2SSTS)**

| Register    | Offset       | R/W | Description         |  |  |  | Reset Value |
|-------------|--------------|-----|---------------------|--|--|--|-------------|
| SPIx_I2SSTS | SPIx_BA+0x68 | R/W | I2S Status Register |  |  |  | 0x0005_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  | Reserved | 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       | <b>Transmit FIFO Data Count (Read Only)</b><br>This bit field indicates the valid data count of transmit FIFO buffer.                                                                                                                                                                                                                                       |
| [27]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                   |
| [26:24] | RXCNT       | <b>Receive FIFO Data Count (Read Only)</b><br>This bit field indicates the valid data count of receive FIFO buffer.                                                                                                                                                                                                                                         |
| [23]    | TXRXRST     | <b>TX or RX Reset Status (Read Only)</b><br>0 = The reset function of TXRST or RXRST is done.<br>1 = Doing the reset function of TXRST or RXRST.<br><b>Note:</b> 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]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                   |
| [21]    | LZCIF       | <b>Left Channel Zero Cross Interrupt Flag</b><br>0 = No zero cross event occurred on left channel.<br>1 = Zero cross event occurred on left channel.                                                                                                                                                                                                        |
| [20]    | RZCIF       | <b>Right Channel Zero Cross Interrupt Flag</b><br>0 = No zero cross event occurred on right channel.<br>1 = Zero cross event occurred on right channel.                                                                                                                                                                                                     |
| [19]    | TXUFIF      | <b>Transmit FIFO Underflow Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it.                                                                                       |
| [18]    | TXTHIF      | <b>Transmit FIFO Threshold Interrupt Flag (Read Only)</b><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.<br><br><b>Note:</b> If TXTHIEN = 1 and TXTHIF = 1, the SPI/I <sup>2</sup> S controller will generate a SPI interrupt request.                                                                                                                                                                                                                                                                                                    |
| [17]    | <b>TXFULL</b>   | <b>Transmit FIFO Buffer Full Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not full.<br>1 = Transmit FIFO buffer is full.                                                                                                                                                                                                                                                                                                            |
| [16]    | <b>TXEMPTY</b>  | <b>Transmit FIFO Buffer Empty Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not empty.<br>1 = Transmit FIFO buffer is empty.                                                                                                                                                                                                                                                                                                         |
| [15]    | <b>I2SENSTS</b> | <b>I<sup>2</sup>S Enable Status (Read Only)</b><br>0 = The SPI/I <sup>2</sup> S control logic is disabled.<br>1 = The SPI/I <sup>2</sup> S control logic is enabled.<br><b>Note:</b> The SPI peripheral clock is asynchronous with the system clock. In order to make sure the SPI/I <sup>2</sup> S control logic is disabled, this bit indicates the real status of SPI/I <sup>2</sup> S control logic for user.                               |
| [14:13] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [12]    | <b>RXTOIF</b>   | <b>Receive Time-out Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it. |
| [11]    | <b>RXOVIF</b>   | <b>Receive FIFO Overrun Interrupt Flag</b><br>When the receive FIFO buffer is full, the follow-up data will be dropped and this bit will be set to 1.<br><b>Note:</b> This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                              |
| [10]    | <b>RXTHIF</b>   | <b>Receive FIFO Threshold Interrupt Flag (Read Only)</b><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><b>Note:</b> If RXTHIEN = 1 and RXTHIF = 1, the SPI/I <sup>2</sup> S controller will generate a SPI interrupt request.                                       |
| [9]     | <b>RXFULL</b>   | <b>Receive FIFO Buffer Full Indicator (Read Only)</b><br>0 = Receive FIFO buffer is not full.<br>1 = Receive FIFO buffer is full.                                                                                                                                                                                                                                                                                                               |
| [8]     | <b>RXEMPTY</b>  | <b>Receive FIFO Buffer Empty Indicator (Read Only)</b><br>0 = Receive FIFO buffer is not empty.<br>1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                                                                                            |
| [7:5]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [4]     | <b>RIGHT</b>    | <b>Right Channel (Read Only)</b><br>This bit indicates the current transmit data is belong to which channel.<br>0 = Left channel.<br>1 = Right channel.                                                                                                                                                                                                                                                                                         |
| [3:0]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |

## 6.20 Quad Serial Peripheral Interface (QSPI)

### 6.20.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 M480 series 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.

### 6.20.2 Features

- Supports Master or Slave mode operation
- Master mode up to 100 MHz and Slave mode up to 100 MHz (when chip works at VDD = 2.7~3.6V)
- 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.20.3 Block Diagram



Figure 6.20-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.20.4 Basic Configuration

### 6.20.4.1 QSPI0 Basic Configuration

- Clock source Configuration
  - Select the source of QSPI0 peripheral clock on QSPI0SEL (CLK\_CLKSEL2[3:2]).
  - Enable QSPI0 peripheral clock in QSPI0CKEN (CLK\_APBCLK0[12]).
- Reset Configuration

- Reset QSPI0 controller in QSPI0RST (SYS\_IPRST1[12]).
- Pin Configuration

| Group | Pin Name    | GPIO        | MFP  |
|-------|-------------|-------------|------|
| QSPI0 | QSPI0_CLK   | PA.2, PH.8  | MFP3 |
|       |             | PC.2        | MFP4 |
|       |             | PF.2        | MFP5 |
|       |             | PC.14       | MFP6 |
|       | QSPI0_MISO0 | PA.1, PE.1  | MFP3 |
|       |             | PC.1        | MFP4 |
|       | QSPI0_MISO1 | PA.5, PH.10 | MFP3 |
|       |             | PC.5        | MFP4 |
|       | QSPI0_MOSI0 | PA.0, PE.0  | MFP3 |
|       |             | PC.0        | MFP4 |
|       | QSPI0_MOSI1 | PA.4, PH.11 | MFP3 |
|       |             | PC.4        | MFP4 |
|       | QSPI0_SS    | PA.3, PH.9  | MFP3 |
|       |             | PC.3        | MFP4 |

## 6.20.5 Functional Description

### 6.20.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.20-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. If the clock source of peripheral clock is not system clock, the frequency of QSPI peripheral clock shall be slower than the system clock frequency 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.20-3 QSPI Full-Duplex Master Mode Application Block Diagram



Figure 6.20-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 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 will be set to 1.



Figure 6.20-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 0x3 (3.5 QSPI clock cycles).

#### 6.20.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 SPI 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.20-6 Automatic Slave Selection (SSACTPOL = 0, SUSPITV &gt; 0x2)



Figure 6.20-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV &lt; 0x3)

#### 6.20.5.3 Byte Reorder and Suspend Function

When the transfer is set as MSB first (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.20-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]).



Figure 6.20-9 Timing Waveform for Byte Suspend

#### 6.20.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.20-10 QSPI Half-Duplex Master Mode Application Block Diagram



Figure 6.20-11 QSPI Half-Duplex Slave Mode Application Block Diagram

#### 6.20.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. After enabling this mode, the output QSPI bus clock will be sent out in 6 peripheral clock cycles. In this mode, the data which has been written into transmit FIFO will be loaded into transmit shift register and sent out.

#### 6.20.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.20.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.

**Note:** QSPI supports single request PDMA (Read/Write) only, burst request PDMA is not supported.

#### 6.20.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\_MOSI0 pin and the odd data (TX Data (n+1)) stored in the QSPIx\_TX register will be transmitted through the QSPIx\_MOSI1 pin respectively. In the meanwhile, the even data received from QSPIx\_MISO0 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\_RX 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\_MOSI0 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.20-12 Two-bit Transfer Mode System Architecture



Figure 6.20-13 Two-bit Transfer Mode Timing (Master Mode)

#### 6.20.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\_MOSI0 is the even bit data output and the QSPIx\_MISO0 will be set as the odd bit data output. If the DUALIOEN (QSPIx\_CTL[21]) is set as 1 and DATDIR (QSPIx\_CTL[20]) is set as 0, both the QSPIx\_MISO0 and QSPIx\_MOSI0 will be set as data input ports.



Figure 6.20-14 Bit Sequence of Dual Output Mode



Figure 6.20-15 Bit Sequence of Dual Input Mode

#### 6.20.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\_MOSI0 and QSPIx\_MOSI1 are the even bit data output and the QSPIx\_MISO0 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\_MOSI0 and QSPIx\_MOSI1 pins will be set as data input ports.



Figure 6.20-16 Bit Sequence of Quad Output Mode



Figure 6.20-17 Bit Sequence of Quad Input Mode

### 6.20.5.11 FIFO Buffer Operation

The QSPI 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 (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 SPI bus. (e.g. the slave selection signal is active and the QSPI controller is receiving data in Slave mode). It will set to 0 when the transmit FIFO is empty and the current transaction has done. Thus, the status of BUSY (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.20-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.20-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, 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.20-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 Example). 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 Example).



Figure 6.20-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.20-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.20-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.20-23 TX Underflow Event (QSPI0 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 Example figure). If the 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.



Figure 6.20-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.20-25 Slave Time-out Event

A receive time-out function is built-in in this controller. When the receive FIFO is not empty and no read operation in receive FIFO over 64 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.20.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 TXUFIIF (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 goes 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 SLVURIEN (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 TXUFIIF (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.20.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.20-26 QSPI Timing in Master Mode



Figure 6.20-27 QSPI Timing in Master Mode (Alternate Phase of QSPIx\_CLK)



Figure 6.20-28 QSPI Timing in Slave Mode



Figure 6.20-29 QSPI Timing in Slave Mode (Alternate Phase of QSPIx\_CLK)

## 6.20.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 off-chip 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] = 0x08).
  - 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 deactivate 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.20.8 Register Map

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

| Register                                          | Offset        | R/W | Description                        | Reset Value |
|---------------------------------------------------|---------------|-----|------------------------------------|-------------|
| <b>QSPI Base Address:</b>                         |               |     |                                    |             |
| <b>QSPIx_BA = 0x4006_0000 + (0x0000_1000 * x)</b> |               |     |                                    |             |
|                                                   | x=0           |     |                                    |             |
| <b>QSPIx_CTL</b>                                  | QSPIx_BA+0x00 | R/W | QSPI Control Register              | 0x0000_0034 |
| <b>QSPIx_CLKDIV</b>                               | QSPIx_BA+0x04 | R/W | QSPI Clock Divider Register        | 0x0000_0000 |
| <b>QSPIx_SSCTL</b>                                | QSPIx_BA+0x08 | R/W | QSPI Slave Select Control Register | 0x0000_0000 |
| <b>QSPIx_PDMACTL</b>                              | QSPIx_BA+0x0C | R/W | QSPI PDMA Control Register         | 0x0000_0000 |
| <b>QSPIx_FIFOCTL</b>                              | QSPIx_BA+0x10 | R/W | QSPI FIFO Control Register         | 0x4400_0000 |
| <b>QSPIx_STATUS</b>                               | QSPIx_BA+0x14 | R/W | QSPI Status Register               | 0x0005_0110 |
| <b>QSPIx_TX</b>                                   | QSPIx_BA+0x20 | W   | QSPI Data Transmit Register        | 0x0000_0000 |
| <b>QSPIx_RX</b>                                   | QSPIx_BA+0x30 | R   | QSPI Data Receive Register         | 0x0000_0000 |

### 6.20.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 |  |  |  | 0x0000_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    | <b>Quad I/O Mode Enable Bit</b><br>0 = Quad I/O mode Disabled.<br>1 = Quad I/O mode Enabled.                                                                                                                                                                                                                                                                   |
| [21]    | DUALIOEN    | <b>Dual I/O Mode Enable Bit</b><br>0 = Dual I/O mode Disabled.<br>1 = Dual I/O mode Enabled.                                                                                                                                                                                                                                                                   |
| [20]    | DATDIR      | <b>Data Port Direction Control</b><br>This bit is used to select the data input/output direction in half-duplex transfer and Dual/Quad transfer<br>0 = QSPI data is input direction.<br>1 = QSPI data is output direction.                                                                                                                                     |
| [19]    | REORDER     | <b>Byte Reorder Function Enable Bit</b><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><b>Note:</b> Byte Reorder function is only available if DWIDTH is defined as 16, 24, and 32 bits. |
| [18]    | SLAVE       | <b>Slave Mode Control</b><br>0 = Master mode.<br>1 = Slave mode.                                                                                                                                                                                                                                                                                               |
| [17]    | UNITIEN     | <b>Unit Transfer Interrupt Enable Bit</b><br>0 = QSPI unit transfer interrupt Disabled.<br>1 = QSPI unit transfer interrupt Enabled.                                                                                                                                                                                                                           |
| [16]    | TWOBIT      | <b>2-bit Transfer Mode Enable Bit</b><br>0 = 2-bit Transfer mode Disabled.                                                                                                                                                                                                                                                                                     |

|        |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         | 1 = 2-bit Transfer mode Enabled.<br><br><b>Note:</b> When 2-bit Transfer mode is enabled, the first serial transmitted bit data is from the first FIFO buffer data, and the 2 <sup>nd</sup> 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 <sup>nd</sup> received bit data is stored into the second FIFO buffer at the same time.                                                                                                                                                                                                                                                                                      |
| [15]   | RXONLY  | <b>Receive-only Mode Enable Bit (Master Only)</b><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.<br>0 = Receive-only mode Disabled.<br>1 = Receive-only mode Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [14]   | HALFDPX | <b>QSPI Half-duplex Transfer Enable Bit</b><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     | <b>Send LSB First</b><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  | <b>Data Width</b><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>DWIDHT = 0x08 .... 8 bits.<br>DWIDHT = 0x09 .... 9 bits.<br>.....<br>DWIDHT = 0x1F .... 31 bits.<br>DWIDHT = 0x00 .... 32 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [7:4]  | SUSPITV | <b>Suspend Interval (Master Only)</b><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 0x3. The period of the suspend interval is obtained according to the following equation.<br>$(\text{SUSPITV}[3:0] + 0.5) * \text{period of QSPICLK clock cycle}$<br>Example:<br>SUSPITV = 0x0 .... 0.5 QSPICLK clock cycle.<br>SUSPITV = 0x1 .... 1.5 QSPICLK clock cycle.<br>.....<br>SUSPITV = 0xE .... 14.5 QSPICLK clock cycle.<br>SUSPITV = 0xF .... 15.5 QSPICLK clock cycle. |
| [3]    | CLKPOL  | <b>Clock Polarity</b><br>0 = QSPI bus clock is idle low.<br>1 = QSPI bus clock is idle high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [2]    | TXNEG   | <b>Transmit on Negative Edge</b><br>0 = Transmitted data output signal is changed on the rising edge of QSPI bus clock.<br>1 = Transmitted data output signal is changed on the falling edge of QSPI bus clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|     |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | RXNEG | <b>Receive on Negative Edge</b><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] | SPIEN | <b>QSPI Transfer Control Enable Bit</b><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.<br>0 = Transfer control Disabled.<br>1 = Transfer control Enabled.<br><b>Note:</b> Before changing the configurations of QSPIx_CTL, QSPIx_CLKDIV, QSPIx_SSCTL and QSPIx_FIFOCTL registers, user shall clear the SPIEN (QSPIx_CTL[0]) and confirm 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 |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [8:0]  | DIVIDER     | <p><b>Clock Divider</b></p> <p>The value in this field is the frequency divider for generating the peripheral clock, <math>f_{spi\_eclk}</math>, and the QSPI bus clock of QSPI Master. The frequency is obtained according to the following equation.</p> $f_{spi\_eclk} = \frac{f_{spi\_clock\_src}}{(DIVIDER + 1)}$ <p>where</p> <p><math>f_{spi\_clock\_src}</math> is the peripheral clock source, which is defined in the clock control register, CLK_CLKSEL2.</p> |

**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 |  |  |  | 0x0000_0000 |

|          |          |          |          |          |          |          |          |
|----------|----------|----------|----------|----------|----------|----------|----------|
| 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
| SLVTOCNT |          |          |          |          |          |          |          |
| 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| SLVTOCNT |          |          |          |          |          |          |          |
| 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved |          | SSINAIEN | SSACTIEN | Reserved |          | SLVURIEN | SLVBEIEN |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved | SLVTORST | SLVTOIEN | SLV3WIRE | AUTOSS   | SSACTPOL | Reserved | SS       |

| Bits    | Description |                                                                                                                                                                                                                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | SLVTOCNT    | <b>Slave Mode Time-out Period</b><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    | <b>Slave Select Inactive Interrupt Enable Bit</b><br>0 = Slave select inactive interrupt Disabled.<br>1 = Slave select inactive interrupt Enabled.                                                                                                                                                      |
| [12]    | SSACTIEN    | <b>Slave Select Active Interrupt Enable Bit</b><br>0 = Slave select active interrupt Disabled.<br>1 = Slave select active interrupt Enabled.                                                                                                                                                            |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |
| [9]     | SLVURIEN    | <b>Slave Mode TX Under Run Interrupt Enable Bit</b><br>0 = Slave mode TX under run interrupt Disabled.<br>1 = Slave mode TX under run interrupt Enabled.                                                                                                                                                |
| [8]     | SLVBEIEN    | <b>Slave Mode Bit Count Error Interrupt Enable Bit</b><br>0 = Slave mode bit count error interrupt Disabled.<br>1 = Slave mode bit count error interrupt Enabled.                                                                                                                                       |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |
| [6]     | SLVTORST    | <b>Slave Mode Time-out Reset Control</b><br>0 = When Slave mode time-out event occurs, the TX and RX control circuit will not be reset.<br>1 = When Slave mode time-out event occurs, the TX and RX control circuit will be reset by hardware.                                                          |
| [5]     | SLVTOIEN    | <b>Slave Mode Time-out Interrupt Enable Bit</b><br>0 = Slave mode time-out interrupt Disabled.<br>1 = Slave mode time-out interrupt Enabled.                                                                                                                                                            |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | <b>SLV3WIRE</b> | <b>Slave 3-wire Mode Enable Bit</b><br>In Slave 3-wire mode, the QSPI controller can work with 3-wire interface including QSPIx_CLK, QSPIx_MISO and SPIx_MOSI pins.<br>0 = 4-wire bi-direction interface.<br>1 = 3-wire bi-direction interface.                                                                                                                                                                                                                                                             |
| [3] | <b>AUTOSS</b>   | <b>Automatic Slave Selection Function Enable Bit (Master Only)</b><br>0 = Automatic slave selection function Disabled. Slave selection signal will be asserted/de-asserted according to SS (QSPIx_SSCTL[0]).<br>1 = Automatic slave selection function Enabled.                                                                                                                                                                                                                                             |
| [2] | <b>SSACTPOL</b> | <b>Slave Selection Active Polarity</b><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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [0] | <b>SS</b>       | <b>Slave Selection Control (Master Only)</b><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.<br>If the AUTOSS bit is set to 1,<br>0 = Keep the QSPIx_SS line at inactive state.<br>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 |  |  |  | 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     | <b>PDMA Reset</b><br>0 = No effect.<br>1 = Reset the PDMA control logic of the QSPI controller. This bit will be automatically cleared to 0.                                                                                                                                                                                                                                |
| [1]    | RXPDMAEN    | <b>Receive PDMA Enable Bit</b><br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.                                                                                                                                                                                                                                                                 |
| [0]    | TXPDMAEN    | <b>Transmit PDMA Enable Bit</b><br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled.<br><b>Note:</b> 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. |

## 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 | RXFBCCLR |
| 7        | 6       | 5       | 4       | 3        | 2       | 1       | 0        |
| TXUFIEN  | TXUFPOL | RXOVIEN | RXTOIEN | TXTHIEN  | RXTHIEN | TXRST   | RXRST    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [30:28] | TXTH        | <b>Transmit FIFO Threshold</b><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        | <b>Receive FIFO Threshold</b><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     | <b>Transmit FIFO Buffer Clear</b><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><b>Note:</b> The TX shift register will not be cleared. |
| [8]     | RXFBCCLR    | <b>Receive FIFO Buffer Clear</b><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><b>Note:</b> The RX shift register will not be cleared.   |
| [7]     | TXUFIEN     | <b>TX Underflow Interrupt Enable Bit</b><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.<br>0 = Slave TX underflow interrupt Disabled.<br>1 = Slave TX underflow interrupt Enabled.                           |
| [6]     | TXUFPPOL    | TX Underflow Data Polarity                                                                                                                                                                                                                                                                                        |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                | 0 = The QSPI data out is keep 0 if there is TX underflow event in Slave mode.<br>1 = The QSPI data out is keep 1 if there is TX underflow event in Slave mode.<br><b>Note:</b><br>1. The TX underflow event occurs if there is no any data in TX FIFO when the slave selection signal is active.<br>2. When TX underflow event occurs, QSPIx_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 QSPIx_MISO pin in the next transfer frame. |
| [5] | <b>RXOVIEN</b> | <b>Receive FIFO Overrun Interrupt Enable Bit</b><br>0 = Receive FIFO overrun interrupt Disabled.<br>1 = Receive FIFO overrun interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                   |
| [4] | <b>RXTOIEN</b> | <b>Slave Receive Time-out Interrupt Enable Bit</b><br>0 = Receive time-out interrupt Disabled.<br>1 = Receive time-out interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                         |
| [3] | <b>TXTHIEN</b> | <b>Transmit FIFO Threshold Interrupt Enable Bit</b><br>0 = TX FIFO threshold interrupt Disabled.<br>1 = TX FIFO threshold interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                      |
| [2] | <b>RXTHIEN</b> | <b>Receive FIFO Threshold Interrupt Enable Bit</b><br>0 = RX FIFO threshold interrupt Disabled.<br>1 = RX FIFO threshold interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                       |
| [1] | <b>TXRST</b>   | <b>Transmit Reset</b><br>0 = 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 (QSPIx_STATUS[23]) to check if reset is accomplished or not.<br><b>Note:</b> If TX underflow event occurs in QSPI Slave mode, this bit can be used to make SPI return to idle state.                     |
| [0] | <b>RXRST</b>   | <b>Receive Reset</b><br>0 = 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 (QSPIx_STATUS[23]) to check if reset is accomplished or not.                                                                                                                                                |

**QSPI Status Register (QSPIx\_STATUS)**

| Register     | Offset        | R/W | Description          |  |  |  | Reset Value |
|--------------|---------------|-----|----------------------|--|--|--|-------------|
| QSPIx_STATUS | QSPIx_BA+0x14 | R/W | QSPI Status Register |  |  |  | 0x0005_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       | <b>Transmit FIFO Data Count (Read Only)</b><br>This bit field indicates the valid data count of transmit FIFO buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [27:24] | RXCNT       | <b>Receive FIFO Data Count (Read Only)</b><br>This bit field indicates the valid data count of receive FIFO buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [23]    | TXRXRST     | <b>TX or RX Reset Status (Read Only)</b><br>0 = The reset function of TXRST or RXRST is done.<br>1 = Doing the reset function of TXRST or RXRST.<br><b>Note:</b> 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      | <b>TX Underflow Interrupt Flag</b><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><b>Note 1:</b> This bit will be cleared by writing 1 to it.<br><b>Note 2:</b> 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      | <b>Transmit FIFO Threshold Interrupt Flag (Read Only)</b><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      | <b>Transmit FIFO Buffer Full Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | 1 = Transmit FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [16]    | <b>TXEMPTY</b>  | <b>Transmit FIFO Buffer Empty Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not empty.<br>1 = Transmit FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                                              |
| [15]    | <b>SPIENSTS</b> | <b>QSPI Enable Status (Read Only)</b><br>0 = QSPI controller Disabled.<br>1 = QSPI controller Enabled.<br><b>Note:</b> 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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [12]    | <b>RXTOIF</b>   | <b>Receive Time-out Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it.                                                  |
| [11]    | <b>RXOVIF</b>   | <b>Receive FIFO Overrun Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                        |
| [10]    | <b>RXTHIF</b>   | <b>Receive FIFO Threshold Interrupt Flag (Read Only)</b><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]     | <b>RXFULL</b>   | <b>Receive FIFO Buffer Full Indicator (Read Only)</b><br>0 = Receive FIFO buffer is not full.<br>1 = Receive FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                                                    |
| [8]     | <b>RXEMPTY</b>  | <b>Receive FIFO Buffer Empty Indicator (Read Only)</b><br>0 = Receive FIFO buffer is not empty.<br>1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                                                 |
| [7]     | <b>SLVURIF</b>  | <b>Slave Mode TX Under Run Interrupt Flag</b><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><b>Note:</b> This bit will be cleared by writing 1 to it.                                                                                                                                                                      |
| [6]     | <b>SLVBEIF</b>  | <b>Slave Mode Bit Count Error Interrupt Flag</b><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><b>Note:</b> 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]     | <b>SLVTOIF</b>  | <b>Slave Time-out Interrupt Flag</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                | <p>When the slave select is active and the value of SLVTOCNT is not 0, as 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 (QSPIx_SSCTL[31:16]) before one transaction is done, the slave time-out interrupt event will be asserted.</p> <p>0 = Slave time-out is not active.<br/>1 = Slave time-out is active.</p> <p><b>Note:</b> This bit will be cleared by writing 1 to it.</p>                                                                                                                                                                                                                                               |
| [4] | <b>SSLINE</b>  | <p><b>Slave Select Line Bus Status (Read Only)</b></p> <p>0 = The slave select line status is 0.<br/>1 = The slave select line status is 1.</p> <p><b>Note:</b> 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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [3] | <b>SSINAIF</b> | <p><b>Slave Select Inactive Interrupt Flag</b></p> <p>0 = Slave select inactive interrupt was cleared or not occurred.<br/>1 = Slave select inactive interrupt event occurred.</p> <p><b>Note:</b> Only available in Slave mode. This bit will be cleared by writing 1 to it.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [2] | <b>SSACTIF</b> | <p><b>Slave Select Active Interrupt Flag</b></p> <p>0 = Slave select active interrupt was cleared or not occurred.<br/>1 = Slave select active interrupt event occurred.</p> <p><b>Note:</b> Only available in Slave mode. This bit will be cleared by writing 1 to it.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [1] | <b>UNITIF</b>  | <p><b>Unit Transfer Interrupt Flag</b></p> <p>0 = No transaction has been finished since this bit was cleared to 0.<br/>1 = QSPI controller has finished one unit transfer.</p> <p><b>Note:</b> This bit will be cleared by writing 1 to it.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [0] | <b>BUSY</b>    | <p><b>Busy Status (Read Only)</b></p> <p>0 = QSPI controller is in idle state.<br/>1 = QSPI controller is in busy state.</p> <p>The following lists the bus busy conditions:</p> <ul style="list-style-type: none"> <li>f. QSPIx_CTL[0] = 1 and TXEMPTY = 0.</li> <li>g. For QSPI Master mode, QSPIx_CTL[0] = 1 and TXEMPTY = 1 but the current transaction is not finished yet.</li> <li>h. For QSPI Master mode, QSPIx_CTL[0] = 1 and RXONLY = 1.</li> <li>i. For QSPI Slave mode, the QSPIx_CTL[0] = 1 and there is serial clock input into the QSPI core logic when slave select is active.</li> <li>j. For QSPI Slave mode, the QSPIx_CTL[0] = 1 and the transmit buffer or transmit shift register is not empty even if the slave select is inactive.</li> </ul> |

**QSPI Data Transmit Register (QSPIx\_TX)**

| Register | Offset        | R/W | Description                 |  |  |  |  | Reset Value |
|----------|---------------|-----|-----------------------------|--|--|--|--|-------------|
| QSPIx_TX | QSPIx_BA+0x20 | W   | QSPI Data Transmit Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | TX          | <p><b>Data Transmit Register</b></p> <p>The data transmit registers pass through the transmitted data into the 8-level transmit FIFO buffers. The number of valid bits depends on the setting of DWIDTH (QSPIx_CTL[12:8]) in QSPI mode.</p> <p>In QSPI mode, if DWIDTH is set to 0x08, the bits TX[7:0] will be transmitted. If DWIDTH is set to 0x00, the QSPI controller will perform a 32-bit transfer.</p> <p><b>Note:</b> In Master mode, QSPI controller will start to transfer the QSPI bus clock after 1 APB clock and 6 peripheral clock cycles after user writes to this register.</p> |

**QSPI Data Receive Register (QSPIx\_RX)**

| Register | Offset        | R/W | Description                |  |  |  |  | Reset Value |
|----------|---------------|-----|----------------------------|--|--|--|--|-------------|
| QSPIx_RX | QSPIx_BA+0x30 | R   | QSPI Data Receive Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | RX          | <p><b>Data Receive Register (Read Only)</b></p> <p>There are 8-level FIFO buffers in this controller. The data receive register holds the data received from QSPI data input pin. If the RXEMPTY (QSPIx_STATUS[8]) is not set to 1, the receive FIFO buffers can be accessed through software by reading this register.</p> |

## 6.21 SPI Synchronous Serial Interface Controller (SPI Master mode)

### 6.21.1 Overview

The SPI Synchronous serial Interface Controller for SPI master mode performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data received from MCU. This SPI controller can drive one external peripheral (External SPI Flash) and it is seen as the SPI master mode. It can generate an interrupt signal when data transfer is finished and can be cleared by writing 1 to the interrupt flag. The active level of device/slave select signal can be chosen to low active or high active, which depends on the peripheral. Writing a divisor into the SPIM\_CTL1 register can program the frequency of serial clock output to the peripheral.

In SPI Flash controller, normal I/O mode contains four 32-bit transmit/receive buffers, and can provide 1 to 4 burst mode operation. The number of bits in each transaction can be 8, 16, 24, or 32; data can be transmitted/received up to four successive transactions in one transfer.

By DMA write mode, user can move data from SRAM to external SPI Flash component. In DMA read mode, user can move data from external SPI Flash component to SRAM. In direct memory mapping mode (DMM mode), this SPI Flash controller will translate the AHB bus commands into SPI Flash operations without MCU setting related SPI Flash command. Therefore users can access external SPI Flash as a ROM module.

In direct memory mapping mode with cache off mode, it will pre-fetch 4-word Flash data after a direct memory mapping access. when using direct memory mapping mode with cache on mode, it will use 32 Kbytes cache memory to reduce the number of accessing external SPI Flash component and the performance of SPI Flash access can be improved. To improve the read operation of SPI Flash without increasing the serial clock frequency, this SPI Flash controller supports DTR/DDR (Double Transfer Rate/Double Data Rate) read command codes that support Standard/Dual/Quad SPI modes. The one byte command code is still latched into the device on the rising edge of the serial clock similar to all other SPI commands. Once a DTR/DDR instruction code is accepted by the device, the address input and data output will be latched on both rising and falling edges of the serial clock.

In core coupled memory mode (CCM mode), the cache function is disabled by hardware automatically, and MCU can access this 32 Kbytes cache memory as general SRAM. For data protection, this SPI Flash controller supports cipher encryption and decryption circuits to protect data which user places into external SPI Flash when DMA read/write mode and direct memory mapping mode are used.

### 6.21.2 Features

- Supports maximum 32M bytes SPI Flash size
- Supports SPI master mode
- Supports Direct Memory Mapping Mode and Normal I/O Mode
- Supports 8/16/24/32 bits transaction for Normal I/O mode
- Provides burst mode operation in Normal I/O mode, which can transmit/receive data up to four successive transactions in one transfer
- Supports DMA mode read/write
- Supports standard (1-bit), dual (2-bit), and quad (4-bit) I/O transfer mode
- Supports Double Transfer Rate (DTR) / Double Data Rate (DDR) transfer mode
- Supports 32 Kbytes cache memory
- Supports 32 Kbytes Core Coupled Memory (CCM) when cache function disable
- Supports Cipher encryption/decryption

- One slave/device select line for external SPI Flash component

### 6.21.3 Block Diagram



Figure 6.21-1 SPIM Block Diagram

### 6.21.4 Basic Configuration

- Clock Source Configuration
  - Enable SPIM peripheral clock in SPIMCKEN (CLK\_AHCLK[14]).
- Reset Configuration
  - Reset SPIM controller in SPIMRST (SYS\_IPRST0[14]).
- Pin Configuration

| Group | Pin Name | GPIO        | MFP  |
|-------|----------|-------------|------|
| SPIM  | SPIM_CLK | PA.2        | MFP2 |
|       |          | PC.2        | MFP3 |
|       |          | PE.4, PG.12 | MFP4 |
|       | SPIM_D2  | PA.5        | MFP2 |
|       |          | PC.5        | MFP3 |

|           |             |      |
|-----------|-------------|------|
|           | PE.7, PG.9  | MFP4 |
| SPIM_D3   | PA.4        | MFP2 |
|           | PC.4        | MFP3 |
|           | PE.6, PG.10 | MFP4 |
| SPIM_MISO | PA.1        | MFP2 |
|           | PC.1        | MFP3 |
|           | PE.3, PG.13 | MFP4 |
| SPIM_MOSI | PA.0        | MFP2 |
|           | PC.0        | MFP3 |
|           | PE.2, PG.14 | MFP4 |
| SPIM_SS   | PA.3        | MFP2 |
|           | PC.3        | MFP3 |
|           | PE.5, PG.11 | MFP4 |

### 6.21.5 Functional Description

#### 6.21.5.1 SPIM Timing Diagram

The timing diagram of SPI transaction is shown as follows:



Figure 6.21-2 SPIM Timing Diagram

#### 6.21.5.2 SPIM Programming Example without DMA (Normal I/O Mode)

To access a device with the following requirements, where the timing diagram is shown in Figure 6.21-2:

- Data is transferred with the MSB first.
- Only one byte is transmitted/received in a transfer.
- Chip select signal is active low.
- User should do the following actions basically (refer to the specification of the device for the detailed steps):

1. Write a divisor into DIVIDER (SPIM\_CTL1[31:16]) to determine the frequency of serial clock.

2. Set SACTPOL (SPIM\_CTL1[5]) to 0 to activate the device you want to access.
3. When transmitting (writing) data to device:
  - QDIODIR (SPIM\_CTL0[15]) = 1
  - BURSTNUM (SPIM\_CTL0[14:13]) = 0x0
  - DWIDTH (SPIM\_CTL0[12:8]) = 0x07
  - Write the data you want to transmit into SPIM\_TX0[7:0]
4. When receiving (reading) data from device:
  - QDIODIR (SPIM\_CTL0[15]) = 0
  - BURSTNUM (SPIM\_CTL0[14:13]) = 0x0
  - DWIDTH (SPIM\_CTL0[12:8]) = 0x07
5. Set SPIMEN (SPIM\_CTL1[0]) to 1 to start the transfer.
6. Wait for interrupt or poll the SPIMEN (SPIM\_CTL1[0]) until it turns to 0.
7. When receiving (reading) data from device:
  - Read out the received data from the SPIM\_RX0[7:0] register.

#### 6.21.5.3 SPIM Programming Example with DMA

If user wants to access a device with DMA function, three additional registers need to be configured, including SPIM\_DMACNT, SPIM\_SRAMADDR and SPIM\_FADDR. The DMA function can be used to support loading code (reading data from the peripheral into system memory) or reading data from system memory and storing the data in the peripheral. Users must define the source, length and destination, and then hardware will automatically move the desired length of code to the specific target address. It is recommended to send disable commands of continuous read mode and burst wrap mode to external SPI Flash component before using DMA read/write operations to transfer data between SRAM and SPI Flash.

#### 6.21.5.4 Move Data from SPI Flash to System Memory (DMA Read Mode)

Step 1: Check device ID by using normal I/O mode to confirm the device has connected.

Step 2:

1. Set the target memory address into the SPIM\_SRAMADDR register.
2. Set the code length into the SPIM\_DMACNT register.
3. Set the SPI Flash start address in the SPIM\_FADDR register.
4. Set OPMODE (SPIM\_CTL0[23:22]) with the DMA Read mode.
5. Set CMDCODE (SPIM\_CTL0[31:24]) with the 0x03 command code.
6. Set SPIMEN (SPIM\_CTL1[0]) to start. Then SPIM will move the code block from SPIM\_FADDR to SPIM\_SRAMADDR with the transfer length set in SPIM\_DMACNT.
7. Wait for interrupt or poll the SPIMEN (SPIM\_CTL1[0]) bit until it turns to 0.

If the used SPI Flash supports other associated read commands, users can also use the following read command codes.

- Fast Read (0Bh), set CMDCODE (SPIM\_CTL0[31:24]) with 0x0B.
- Fast Read Dual Output (3Bh), set CMDCODE (SPIM\_CTL0[31:24]) with 0x3B.
- Fast Read Dual I/O (BBh), set CMDCODE (SPIM\_CTL0[31:24]) with 0xBB.
- Fast Read Quad I/O (EBh), set CMDCODE (SPIM\_CTL0[31:24]) with 0xEB.

- Word Read Quad I/O (E7h), set CMDCODE (SPIM\_CTL0[31:24]) with 0xE7.
- DTR/DDR Fast Read (0Dh), set CMDCODE (SPIM\_CTL0[31:24]) with 0x0D.
- DTR/DDR Fast Read Dual I/O (BDh), set CMDCODE (SPIM\_CTL0[31:24]) with 0xBD.
- DTR/DDR Fast Read Quad I/O (EDh), set CMDCODE (SPIM\_CTL0[31:24]) with 0xED.

#### 6.21.5.5 Move Data from System Memory to SPI Flash (DMA Write Mode)

Step 1: Erase the SPI Flash (using normal I/O mode) before programming it.

Step 2:

- Send Write Enable command to SPI Flash (using normal I/O mode).
- Set the source memory address in the SPIM\_SRAMADDR register.
- Set the transfer count into the SPIM\_DMACNT register.
- Set the SPI Flash start address in the SPIM\_FADDR register.
- Set OPMODE (SPIM\_CTL0[23:22]) with the DMA Write mode.
- Set CMDCODE (SPIM\_CTL0[31:24]) with the 0x02 command code.
- Set SPIMEN (SPIM\_CTL1[0]) to start.
- Wait for interrupt or poll the SPIMEN (SPIM\_CTL1[0]) until it turns to 0.

If the used SPI Flash supports other associated write commands, users can also use the following command code. (User needs to refer to specification of external SPI Flash component to select suitable quad write mode command.)

- Quad write, set CMDCODE (SPIM\_CTL0[31:24]) to 0x32 for TYPE\_1 program command (refer to Figure 6.21-3).
- Quad write, set CMDCODE (SPIM\_CTL0[31:24]) to 0x38 for TYPE\_2 program command (refer to Figure 6.21-4).
- Quad write, set CMDCODE (SPIM\_CTL0[31:24]) to 0x40 for TYPE\_3 program command (refer to Figure 6.21-5).



Figure 6.21-3 TYPE\_1 Program Command Flow with Quad Mode Write



Figure 6.21-4 TYPE\_2 Program Command Flow with Quad Mode Write



Figure 6.21-5 TYPE\_3 Program Command Flow with Quad Mode Write

#### 6.21.5.6 Direct Memory Mapping Mode

SPI Flash can be regarded as a ROM module in direct memory mapping mode. The controller will convert the AHB cycle into SPI Flash without MCU setting related SPI Flash command. The only setting MCU needs to do is to set CMDCODE(SPI\_M\_CTL0[31:24]) with command codes 0x03, 0x0B, 0x3B, 0xBB, 0xEB, 0xE7, 0x0D, 0xBD, or 0xED. Then users can access SPI Flash as a ROM module.

In direct memory mapping mode with cache off mode, it will pre-fetch 4-word Flash data after a direct memory mapping access. In direct memory mapping mode with cache function on and core coupled memory mode (CCM mode) off, it will use cache memory to reduce the number of accessing external SPI Flash component. Therefore the performance of SPI Flash access can be improved. If users want to modify SPIM hardware registers after the direct memory mapping access, wait for at least 250 peripheral cycles (SPIM bus cycles).

In direct memory mapping mode (DMM mode), quad/dual read commands codes “0xEB, 0xE7, 0xBB” and DTR/DDR read command codes “0x0D, 0xBD, 0xED” support continuous read mode (or performance enhance mode) to reduce the command sequence by eight clocks, and allows the read address data to be entered after chip select of SPI Flash component is asserted low (please check the used SPI Flash specification to know support information). Figure 6.21-6 shows the SPI data transfer of quad I/O mode when the continuous read mode is disabled and address mode is 3 bytes.



Figure 6.21-6 Fast Read Quad I/O Command 0xEB with Continuous Read Mode Disable

Figure 6.21-7 shows the next SPI data transfer of quad I/O mode when the continuous read mode is enabled and address mode is 3 bytes.



Figure 6.21-7 Fast Read Quad I/O Command 0xEB with Continuous Read Mode Enable

List for supported SPI Flash vendors of continuous read mode for read command 0xBB, 0xEB, 0xE7, 0x0D, 0xBD, and 0xED in direct memory mapping mode:

- Supported SPI Flash vendors for read command 0xBB: Winbond only
- Supported SPI Flash vendors for read command 0xEB: Winbond, Gigadevice, Spansion, EON, and MXIC
- Supported SPI Flash vendors for read command 0xE7: Winbond only
- Supported SPI Flash vendors for DTR/DDR read command 0x0D: Check used SPI Flash specification
- Supported SPI Flash vendors for DTR/DDR Dual I/O read command 0xBD: Check used SPI Flash specification
- Supported SPI Flash vendors for DTR/DDR Quad I/O read command 0xED: Check used SPI Flash specification

After using command codes 0xEB, 0xE7, 0x0D, 0xBD, and 0xED to read the last needed SPI Flash data in DMM mode with the continuous read mode on, please use normal I/O mode to send 0xFF (8 SPI clocks for 3 bytes address mode) or 0x3FF (10 SPI clocks for 4 bytes address mode) to the

external SPI Flash on SPI serial interface pin sdo\_0 to disable continuous read mode of the external SPI Flash. Check the used SPI Flash specification to know the information of continuous read mode (or performance enhance mode).

When using command codes “0xBB” to read the last needed SPI Flash data in DMM mode with the continuous read mode on, please use normal I/O mode to send 0xFFFF (16 SPI clocks for 3 bytes address mode) or 0xFFFFFFF (20 SPI clocks for 4 bytes address mode) to the external SPI Flash on SPI serial interface pin sdo\_0. Please check the used SPI Flash specification to know the information of continuous read mode (or performance enhance mode).

Use the following settings of normal I/O mode to send continuous read mode reset to the external SPI Flash. Please check the used SPI Flash specification to know the information of continuous read mode (or performance enhance mode).

**Steps for continuous read mode reset (disable) for command codes 0xEB, 0xE7, 0x0D, 0xBD, 0xED in direct memory mapping mode:**

1. Set OPMODE(SPIM\_CTL0[23:22]) to 0x0 (normal I/O mode)
2. Set BITMODE(SPIM\_CTL0[21:20]) to 0x2 (quad mode, use 4 serial SPI signals to send data to SPI Flash)
3. Set QDIODIR(SPIM\_CTL0[15]) to 0x1 (write mode)
4. Set BURSTNUM(SPIM\_CTL0[14:13]) to 0x0 (only one transmit/receive transaction will be executed in one transfer)
5. Set DWIDTH(SPIM\_CTL0[12:8]) to 0x1F (send 32 bits data to SPI Flash)
6. Set SPIM\_TX0 register to 0xFFFFFFFF
7. Set SPIMEN(SPIM\_CTL1[0]) to start normal I/O operations
8. Polling SPIMEN(SPIM\_CTL1[0]) to check operation status when normal I/O mode is going. (1 = busy, 0 = finish)
9. Set SS(SPIM\_CTL1[4]) to let SPIM\_SS in inactive level

**Steps for continuous read mode reset for command code 0xBB in direct memory mapping mode:**

1. Set OPMODE(SPIM\_CTL0[23:22]) to 0x0 (normal I/O mode)
2. Set BITMODE(SPIM\_CTL0[21:20]) to 0x1 (dual mode, use 2 serial SPI signals to send data to SPI Flash)
3. Set QDIODIR(SPIM\_CTL0[15]) to 0x1 (write mode)
4. Set BURSTNUM(SPIM\_CTL0[14:13]) to 0x0 (only one transmit/receive transaction will be executed in one transfer)
5. Set DWIDTH(SPIM\_CTL0[12:8]) to 0x1F (send 32 bits data to SPI Flash)
6. Set SPIM\_TX0 register to 0xFFFFFFFF
7. Set SPIMEN(SPIM\_CTL1[0]) to start normal I/O operations
8. Polling SPIMEN(SPIM\_CTL1[0]) to check operation status when normal I/O mode is going. (1 = busy, 0 = finish)
9. Set SS(SPIM\_CTL1[4]) to let SPIM\_SS in inactive level

In direct memory mapping mode, both of quad read commands “0xEB” and “0xE7” support burst wrap mode for cache application and performance enhance. For cache application, the burst wrap mode can be used to fill the cache line quickly (In this SPI Flash controller, use cache data line with 16 bytes size). For performance enhance with direct memory mapping mode and cache enable, when cache data is miss, the burst wrap mode can let MCU get the required SPI Flash data quickly. When both of the burst wrap mode and continuous read mode are switched from enable to disable, the continuous

read mode of the external SPI Flash is disabled firstly and then the burst wrap mode of the external SPI Flash is disabled secondly.

Before DMM mode with read command codes “0xEB or 0xE7” and burst wrap mode is used to access external SPI Flash, please use normal I/O mode of SPI Flash controller to send “0x1101\_1101 and 0x2000\_0000” (burst wrap enable command of external SPI Flash, it needs 16 SPI clocks. Please check used SPI Flash specification to know information and setting values for burst wrap mode.) to the external SPI Flash on SPI serial interface pin sdo\_0 ~ sdo\_3. After using command codes “0xEB and 0xE7” to read the last needed SPI Flash data in DMM mode with the burst wrap mode on, please use normal I/O mode of SPI Flash controller to send “0x1101\_1101 and 0x0000\_0000” (burst wrap disable command of external SPI Flash, it needs 16 SPI clocks. Please check used SPI Flash specification to know information and setting values for burst wrap mode.) to the external SPI Flash on SPI serial interface pin sdo\_0 ~ sdo\_3.

Use the following settings of normal I/O mode of SPI Flash controller to send SPI command codes to enable or disable the burst wrap mode for the external SPI Flash.

#### **Steps for burst wrap mode enable in direct memory mapping mode:**

1. Set OPMODE(SPIM\_CTL0[23:22]) to 0x0 (normal I/O mode)
2. Set BITMODE(SPIM\_CTL0[21:20]) to 0x2 (quad mode, use 4 serial SPI signals to send data to SPI Flash)
3. Set QDIODIR(SPIM\_CTL0[15]) to 0x1 (write mode)
4. Set BURSTNUM(SPIM\_CTL0[14:13]) to 0x1 (two successive/receive transaction will be executed in one transfer)
5. Set DWIDTH(SPIM\_CTL0[12:8]) to 0x1F (send 32 bits data to SPI Flash)
6. Set SPIM\_TX0 register to 0x20000000, SPIM\_TX1 register to 0x11011101
7. Set SPIMEN(SPIM\_CTL1[0]) to start normal I/O operations
8. Polling SPIMEN(SPIM\_CTL1[0]) to check operation status when normal I/O mode is going. (1 = busy, 0 = finish)
9. Set SS(SPIM\_CTL1[4]) to let SPIM\_SS in inactive level

#### **Steps for burst wrap mode disable in direct memory mapping mode:**

1. Set OPMODE(SPIM\_CTL0[23:22]) to 0x0 (normal I/O mode)
2. Set BITMODE(SPIM\_CTL0[21:20]) to 0x2 (quad mode, use 4 serial SPI signals to send data to SPI Flash)
3. Set QDIODIR(SPIM\_CTL0[15]) to 0x1 (write mode)
4. Set BURSTNUM(SPIM\_CTL0[14:13]) to 0x1 (two successive/receive transaction will be executed in one transfer)
5. Set DWIDTH(SPIM\_CTL0[12:8]) to 0x1F (send 32 bits data to SPI Flash)
6. Set SPIM\_TX0 register to 0x00000000, SPIM\_TX1 register to 0x11011101
7. Set SPIMEN(SPIM\_CTL1[0]) to start normal I/O operations
8. Polling SPIMEN(SPIM\_CTL1[0]) to check operation status when normal I/O mode is going. (1 = busy, 0 = finish)
9. Set SS(SPIM\_CTL1[4]) to let SPIM\_SS in inactive level

To improve the read operation throughput without increasing the serial clock frequency, this SPI Flash controller supports DTR/DDR (Double Transfer Rate/Double Data Rate) Read command codes (i.e. 0x0D, 0xBD, 0xED) that support Standard/Dual/Quad SPI modes for direct memory mapping mode and DMA read mode. The one byte command code is still latched into the device on the 8 rising edges of the serial clock. Once a DTR/DDR instruction code is accepted by the device, the SPI Flash read

address, mode bits, dummy cycles, and output data, which sends from SPI Flash component will be latched on both rising and falling edges of the serial clock. The timing diagrams for DTR/DDR read command 0x0D, 0xBD, and 0Xed are shown below.



Figure 6.21-8 DTR/DDR Fast read command 0x0D



Figure 6.21-9 DTR/DDR Fast Read Dual I/O Command 0xBD



Figure 6.21-10 DTR/DDR Fast Read Quad I/O Command 0xED

The dummy cycle number depends on SPI Flash vendors, operation frequencies, and command types, and please check used SPI Flash specification to know dummy cycle number correctly.

#### 6.21.5.7 Core Coupled Memory Mode (CCM Mode)

When user sets CCMEN(SPI\_M\_CTL1[2]) to 1, the operation mode of cache memory will be core coupled memory mode (CCM mode). In CCM mode, the cache function of SPI Flash controller is disabled by hardware automatically, and MCU can access this core coupled memory as general SRAM. When user sets CCMEN(SPI\_M\_CTL1[2]) to 0 and MCU accesses CCM address range, SPI Flash controller will generate AHB error response to MCU.

#### 6.21.5.8 Cipher Encryption and Decryption

In the SPI Flash controller, cipher encryption and decryption functions are supported to protect data which user places into external SPI Flash. When DMA write mode is used and cipher function is enabled, cipher circuit will encrypt the data which move from SRAM to external SPI Flash. When DMA read mode is used and cipher function is enabled, cipher circuit will decrypt the data which move from external SPI Flash to SRAM. When direct memory mapping mode is used and cipher function is enabled, cipher circuit will decrypt the data which MCU reads from external SPI Flash. In normal I/O mode, the data which send to external SPI Flash or receive from external SPI Flash are not encrypted and decrypted by cipher circuit.

### 6.21.6 Mapping Address for SPI Flash Controller in AMBA System

| Address Space                                                                                                                                                                                                                                                                            | Token         | Controllers                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mapping address for SPIM control register, SPI Flash memory space, core coupled memory space                                                                                                                                                                                             |               |                                                                                                                                                                                                                                                                                                     |
| 0x4000_7000 – 0x4000_7FFF                                                                                                                                                                                                                                                                | SPIM_BA       | SPIM Control Registers                                                                                                                                                                                                                                                                              |
| (1) When chip SRAM size is 96KB:<br>0x1001_0000 – 0x1001_7FFF<br>0x2001_0000 – 0x2001_7FFF<br>(2) When chip SRAM size is 128KB:<br>0x1001_8000 – 0x1001_FFFF<br>0x2001_8000 – 0x2001_FFFF<br>(3) When chip SRAM size is 160KB:<br>0x1002_0000 – 0x1002_7FFF<br>0x2002_0000 – 0x2002_7FFF | SRAM2_BA      | <p>SRAM Memory Space (32KB) for MCU only and share with SPIM cache (when CCM mode is enabled)</p> <p><b>Note:</b> the chip can be configured as three kinds of SRAM size (160KB/128KB/96KB). Please check the SRAM configuration to confirm the address range which MCU can access in CCM mode.</p> |
| 0x0800_0000 – 0x09FF_FFFF                                                                                                                                                                                                                                                                | SPIM_FLASH_BA | Access address range of SPIM Memory Space (32MB) for Direct Memory Mapping mode (DMM mode).                                                                                                                                                                                                         |

Table 6.21-1 Mapping Address for SPI Flash Controller in AMBA System

### 6.21.7 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 |
|------------------------------|--------------|-----|---------------------------------------------|-------------|
| <b>SPIM Base Address:</b>    |              |     |                                             |             |
| <b>SPIM_BA = 0x4000_7000</b> |              |     |                                             |             |
| <b>SPIM_CTL0</b>             | SPIM_BA+0x00 | R/W | Control and Status Register 0               | 0x00C0_0002 |
| <b>SPIM_CTL1</b>             | SPIM_BA+0x04 | R/W | Control Register 1                          | 0x0000_0010 |
| <b>SPIM_RXCLKDLY</b>         | SPIM_BA+0x0C | R/W | RX Clock Delay Control Register             | 0x0000_010F |
| <b>SPIM_RX0</b>              | SPIM_BA+0x10 | R   | Data Receive Register 0                     | 0x0000_0000 |
| <b>SPIM_RX1</b>              | SPIM_BA+0x14 | R   | Data Receive Register 1                     | 0x0000_0000 |
| <b>SPIM_RX2</b>              | SPIM_BA+0x18 | R   | Data Receive Register 2                     | 0x0000_0000 |
| <b>SPIM_RX3</b>              | SPIM_BA+0x1C | R   | Data Receive Register 3                     | 0x0000_0000 |
| <b>SPIM_TX0</b>              | SPIM_BA+0x20 | R/W | Data Transmit Register 0                    | 0x0000_0000 |
| <b>SPIM_TX1</b>              | SPIM_BA+0x24 | R/W | Data Transmit Register 1                    | 0x0000_0000 |
| <b>SPIM_TX2</b>              | SPIM_BA+0x28 | R/W | Data Transmit Register 2                    | 0x0000_0000 |
| <b>SPIM_TX3</b>              | SPIM_BA+0x2C | R/W | Data Transmit Register 3                    | 0x0000_0000 |
| <b>SPIM_SRAMADDR</b>         | SPIM_BA+0x30 | R/W | SRAM Memory Address Register                | 0x0000_0000 |
| <b>SPIM_DMACNT</b>           | SPIM_BA+0x34 | R/W | DMA Transfer Byte Count Register            | 0x0000_0000 |
| <b>SPIM_FADDR</b>            | SPIM_BA+0x38 | R/W | SPI Flash Address Register                  | 0x0000_0000 |
| <b>SPIM_KEY1</b>             | SPIM_BA+0x3C | W   | Cipher Key1 Register                        | 0x0000_0000 |
| <b>SPIM_KEY2</b>             | SPIM_BA+0x40 | W   | Cipher Key2 Register                        | 0x0000_0000 |
| <b>SPIM_DMMCTL</b>           | SPIM_BA+0x44 | R/W | Direct Memory Mapping Mode Control Register | 0x0008_0000 |
| <b>SPIM_CTL2</b>             | SPIM_BA+0x48 | R/W | Control Register 2                          | 0x0804_0000 |

**Note:** If software wants to write to any register of the peripheral, the SPIMEN bit of the SPIM\_CTL1 register should be the status low.

### 6.21.8 Register Description

#### Control and Status Register 0 (SPIM\_CTL0)

| Register  | Offset       | R/W | Description                   |  |  |  | Reset Value |
|-----------|--------------|-----|-------------------------------|--|--|--|-------------|
| SPIM_CTL0 | SPIM_BA+0x00 | R/W | Control and Status Register 0 |  |  |  | 0x00C0_0002 |

|         |          |          |          |         |       |          |         |
|---------|----------|----------|----------|---------|-------|----------|---------|
| 31      | 30       | 29       | 28       | 27      | 26    | 25       | 24      |
| CMDCODE |          |          |          |         |       |          |         |
| 23      | 22       | 21       | 20       | 19      | 18    | 17       | 16      |
| OPMODE  |          | BITMODE  |          | SUSPITV |       |          |         |
| 15      | 14       | 13       | 12       | 11      | 10    | 9        | 8       |
| QDIODIR | BURSTNUM |          | DWIDTH   |         |       |          |         |
| 7       | 6        | 5        | 4        | 3       | 2     | 1        | 0       |
| IF      | IEN      | B4ADDREN | Reserved |         | BALEN | Reserved | CIPHOFF |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <p><b>Page Program Command Code (Note4)</b><br/>         0x02 = Page program (Used for DMA Write mode).<br/>         0x32 = Quad page program with TYPE_1 program flow (Used for DMA Write mode). (Note3)<br/>         0x38 = Quad page program with TYPE_2 program flow (Used for DMA Write mode). (Note3)<br/>         0x40 = Quad page program with TYPE_3 program flow (Used for DMA Write mode). (Note3)<br/>         The Others = Reserved.</p> <p><b>Read Command Code:</b><br/>         0x03 = Standard Read (Used for DMA Read/DMM mode).<br/>         0x0B = Fast Read (Used for DMA Read/DMM mode).<br/>         The fast read command code “0xB” is similar to command code of standard read “0x03” except it can operate at highest possible frequency. (Note2)</p> <p>0x3B = Fast Read Dual Output (Used for DMA Read/DMM mode).<br/>         0xBB = Fast Read Dual I/O (Used for DMA Read/DMM mode).<br/>         The fast read dual I/O command code “0xBB” is similar to command code of fast read dual output “0x3B” but with capability to input the address bits two bits per clock. (Note2)</p> <p>0xEB = Fast quad read (Used for DMA Read/DMM mode).<br/>         0xE7 = Word quad read (Used for DMA Read/DMM mode).<br/>         The command code of word quad read “0xE7” is similar to command code of fast quad read “0xEB” except that the lowest address bit must equal to 0 and the number of dummy cycles is less than fast quad read. (Note2)</p> <p>0x0D = DTR/DDR Fast read (Used for DMA Read/DMM mode).<br/>         0xBD = DTR/DDR dual read (Used for DMA Read/DMM mode).<br/>         0xED = DTR/DDR quad read (Used for DMA Read/DMM mode).<br/>         The Others command codes are Reserved.<br/>         The DTR/DDR read commands “0x0D,0xBD,0xED” improves throughput by transferring address and data on both the falling and rising edge of SPI Flash clock (SPIM_CLK). It is</p> |

|         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                | <p>similar to those commands “0x0B, 0xBB, 0xEB” but allows transfer of address and data on rising edge and falling edge of SPI Flash output clock. (Note2)</p> <p><b>Note1:</b> Quad mode of SPI Flash must be enabled first by normal I/O mode before using quad page program/quad read commands.</p> <p><b>Note2:</b> See SPI Flash specifications for support items.</p> <p><b>Note3:</b> For TYPE_1, TYPE_2, and TYPE_3 of page program command code, refer to Figure 6.21-3, Figure 6.21-4, and Figure 6.21-5.</p> <p><b>Note4:</b> Please disable “continuous read mode” and “burst wrap mode” before DMA write mode of SPI Flash controller is used to program data of external SPI Flash. After using DMA write mode of SPI Flash controller to program the content of external SPI Flash, please set CDINVAL(SPIM_CTL1[3]) to 0x1 (Set all cache data to be invalid).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [23:22] | <b>OPMODE</b>  | <p><b>SPI Function Operation Mode</b></p> <p>0x0 = Normal I/O mode. (Note1) (Note3)</p> <p>0x1 = DMA write mode. (Note2) (Note3)</p> <p>0x2 = DMA read mode. (Note3)</p> <p>0x3 = Direct Memory Mapping mode (DMM mode) (Default). (Note4)</p> <p><b>Note1:</b> After using Normal I/O mode of SPI Flash controller to program the content of external SPI Flash, please set CDINVAL(SPIM_CTL1[3]) to 0x1 (Set all cache data to be invalid).</p> <p><b>Note2:</b> In DMA write mode, hardware will send just one page program command per operation. Users must take care of cross-page cases. After using DMA write mode of SPI Flash controller to program the content of external SPI Flash, please set CDINVAL(SPIM_CTL1[3]) to 0x1 (Set all cache data to be invalid).</p> <p><b>Note3:</b> For external SPI Flash with 32 MB, access address range of external SPI Flash address is from 0x00000000 to 0x01FFFFFF when using Normal I/O mode, DMA write mode, and DMA read mode to write/read external SPI Flash data. Please user check size of used SPI Flash component to know access address range of external SPI Flash.</p> <p><b>Note4:</b> For external SPI Flash with 32 MB, access address range of external SPI Flash address is from 0x08000000 to 0x09FFFFFF when using Direct Memory mapping mode (DMM mode) to read external SPI Flash data. Please user check size of used SPI Flash component to know access address range of external SPI Flash.</p> |
| [21:20] | <b>BITMODE</b> | <p><b>SPI Interface Bit Mode</b></p> <p>0x0 = Standard mode.</p> <p>0x1 = Dual mode.</p> <p>0x2 = Quad mode.</p> <p>0x3 = Reserved.</p> <p><b>Note:</b> Only used for normal I/O mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [19:16] | <b>SUSPITV</b> | <p><b>Suspend Interval</b></p> <p>These four bits provide the configuration of suspend interval between two successive transmit/receive transactions in a transfer. The default value is 0x00. When BURSTNUM = 00, setting this field has no effect on transfer. The desired interval is obtained according to the following equation (from the last falling edge of current SPI clock to the first rising edge of next SPI clock):</p> <p>(SUSPITV+2)*period of AHB clock</p> <p>0x0 = 2 AHB clock cycles.</p> <p>0x1 = 3 AHB clock cycles.</p> <p>.....</p> <p>0xE = 16 AHB clock cycles.</p> <p>0xF = 17 AHB clock cycles.</p> <p><b>Note:</b> Only used for normal I/O mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [15]    | <b>QDIODIR</b> | <p><b>SPI Interface Direction Select for Quad/Dual Mode</b></p> <p>0 = Interface signals are input.</p> <p>1 = Interface signals are output.</p> <p><b>Note:</b> Only used for normal I/O mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [14:13] | <b>BURSTNUM</b> | <p><b>Transmit/Receive Burst Number</b></p> <p>This field specifies how many transmit/receive transactions should be executed continuously in one transfer.</p> <p>0x0 = Only one transmit/receive transaction will be executed in one transfer.</p> <p>0x1 = Two successive transmit/receive transactions will be executed in one transfer.</p> <p>0x2 = Three successive transmit/receive transactions will be executed in one transfer.</p> <p>0x3 = Four successive transmit/receive transactions will be executed in one transfer.</p> <p><b>Note:</b> Only used for normal I/O Mode.</p>                                |
| [12:8]  | <b>DWIDTH</b>   | <p><b>Transmit/Receive Bit Length</b></p> <p>This specifies how many bits are transmitted/received in one transmit/receive transaction.</p> <p>0x7 = 8 bits.</p> <p>0xF = 16 bits.</p> <p>0x17 = 24 bits.</p> <p>0x1F = 32 bits.</p> <p>Others = Incorrect transfer result.</p> <p><b>Note1:</b> Only used for normal I/O mode.</p> <p><b>Note2:</b> Only 8, 16, 24, and 32 bits are allowed. Other bit length will result in incorrect transfer.</p>                                                                                                                                                                         |
| [7]     | <b>IF</b>       | <p><b>Interrupt Flag</b></p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Write 1 to clear.</p> <p>Read Operation:</p> <p>0 = The transfer has not finished yet.</p> <p>1 = The transfer has done.</p>                                                                                                                                                                                                                                                                                                                                                                                                                |
| [6]     | <b>IEN</b>      | <p><b>Interrupt Enable Bit</b></p> <p>0 = SPIM Interrupt Disabled.</p> <p>1 = SPIM Interrupt Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [5]     | <b>B4ADDREN</b> | <p><b>4-byte Address Mode Enable Bit</b></p> <p>0 = 4-byte address mode Disabled, and 3-byte address mode Enabled.</p> <p>1 = 4-byte address mode Enabled.</p> <p><b>Note:</b> Used for DMA write mode, DMA read mode, and DMM mode.</p>                                                                                                                                                                                                                                                                                                                                                                                      |
| [4:3]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2]     | <b>BALEN</b>    | <p><b>Balance the AHB Control Time Between Cipher Enable and Disable Control</b></p> <p>When cipher is enabled, the AHB control signal will delay some time caused by the encoding or decoding calculation. Therefore, if set BALEN to 1, it will make the AHB signal processing time with cipher disabled be equal to that with cipher enabled.</p> <p><b>Note:</b> Only useful when cipher is disabled.</p>                                                                                                                                                                                                                 |
| [1]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [0]     | <b>CIPHOFF</b>  | <p><b>Cipher Disable Bit</b></p> <p>0 = Cipher function Enabled.</p> <p>1 = Cipher function Disabled.</p> <p><b>Note1:</b> If there is not any KEY1(SPIM_KEY1[31:0]) or KEY2(SPIM_KEY2[31:0]) (KEY1 is 0x0000_0000 or KEY2 is 0x0000_0000), the cipher function will be disabled automatically.</p> <p><b>Note2:</b> When CIPHOFF(SPIM_CTL0[0]) is 0, both of KEY1(SPIM_KEY1[31:0]) and KEY2(SPIM_KEY2[31:0]) do not equal to 0x0000_0000 (i.e. KEY1≠ 0x0000_0000 and KEY2≠ 0x0000_0000), cipher encryption/decryption is enabled.</p> <p><b>Note3:</b> When cipher encryption/decryption is enabled, please set DESELTIM</p> |

|  |                                                                                                                              |
|--|------------------------------------------------------------------------------------------------------------------------------|
|  | (SPIM_DMMCTL[20:16]) >= 0x10. When cipher encryption/decryption is disabled, please set DESELTIM(SPIM_DMMCTL[20:16]) >= 0x8. |
|--|------------------------------------------------------------------------------------------------------------------------------|

**Control Register 1 (SPIM\_CTL1)**

| Register  | Offset       | R/W | Description        |  |  |  | Reset Value |
|-----------|--------------|-----|--------------------|--|--|--|-------------|
| SPIM_CTL1 | SPIM_BA+0x04 | R/W | Control Register 1 |  |  |  | 0x0000_0010 |

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

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>Clock Divider Register</b><br>The value in this field is the frequency divider of the AHB clock (HCLK) to generate the serial SPI output clock "SCLK" on the output SPIM_CLK pin. The desired frequency is obtained according to the following equation:<br>$f_{SPIM\_CLK} = \frac{f_{HCLK}}{(DIVIDER)*2}$ <b>Note1:</b> When set DIVIDER to zero, the frequency of SPIM_CLK will be equal to the frequency of HCLK.<br><b>Note2:</b> SCLK is serial SPI output clock.<br><b>Note3:</b> Please check the specification of the used SPI Flash component to decide the frequency of SPI Flash clock.<br><b>Note4:</b> For DTR/DDR read commands "0x0D, 0xBD, 0xED", the setting values of DIVIDER are only 1,2,4,8,16,32,..., $2^n$ , where n = 0,1,2,3,4, .... |
| [15:12] | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [11:8]  | <b>Idle Time Interval</b><br>In DMM mode, IDLETIME is set to control the minimum idle time between two SPI Flash accesses.<br>Minimum idle time = (IDLETIME + 1) * AHB clock cycle time.<br><b>Note1:</b> Only used for DMM mode.<br><b>Note2:</b> AHB clock cycle time = 1/AHB clock frequency.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [7:6]   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [5]     | <b>Slave Select Active Level</b><br>It defines the active level of device/slave select signal (SPIM_SS), as shown in Table 6.21-2.<br>0 = The SPIM_SS slave select signal is active low.<br>1 = The SPIM_SS slave select signal is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [4]     | <b>Slave Select Active Enable Bit</b><br>0 = SPIM_SS is in active level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|     |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          | 1 = SPIM_SS is in inactive level (Default).<br><br><b>Note:</b> This interface can only drive one device/slave at a given time. Therefore, the slave selects of the selected device must be set to its active level before starting any read or write transfer. Functional description of SSACTPOL(SPIM_CTL1[5]) and SS is shown in Table 6.21-2.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [3] | CDINVAL  | <b>Cache Data Invalid Enable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Set all cache data to be invalid. This bit is cleared by hardware automatically.<br>Read Operation: No effect<br><br><b>Note:</b> When SPI Flash memory is page erasing or whole Flash erasing, please set CDINVAL to 0x1. After using normal I/O mode or DMA write mode of SPI Flash controller to program or erase the content of external SPI Flash, please set CDINVAL to 0x1.                                                                                                                                                                                                                                                                                                                         |
| [2] | CCMEN    | <b>CCM (Core Coupled Memory) Mode Enable Bit</b><br>0 = CCM mode Disabled. (Default)<br>1 = CCM mode Enabled.<br><br><b>Note1:</b> When CCM mode is enabled, the cache function will be disable by hardware automatically. When CCM mode is disabled, the cache function can be enabled or disabled by user.<br><br><b>Note2:</b> When CCM mode is disabled, user accesses the core coupled memory by bus master. In this case, the SPI Flash controller will send error response via HRESP bus signal to bus master.<br><br><b>Note3:</b> When CCM mode needs to be enabled, user sets CCMEN to 1 and needs to read this register to show the current hardware status. When reading data of CCMEN is 1, MCU can start to read data from CCM memory space or write data to CCM memory space. |
| [1] | CACHEOFF | <b>Cache Memory Function Disable Bit</b><br>0 = Cache memory function Enabled. (Default)<br>1 = Cache memory function Disabled.<br><br><b>Note:</b> When CCM mode is enabled, the cache function will be disable by hardware automatically. When CCM mode is disabled, the cache function can be enable or disable by user.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [0] | SPIMEN   | <b>Go and Busy Status</b><br>Write Operation:<br>0 = No effect.<br>1 = Start the transfer. This bit remains set during the transfer and is automatically cleared after transfer finished.<br>Read Operation:<br>0 = The transfer has done.<br>1 = The transfer has not finished yet.<br><br><b>Note:</b> All registers should be set before writing 1 to the SPIMEN bit. When a transfer is in progress, user should not write to any register of this peripheral.                                                                                                                                                                                                                                                                                                                           |

| SSACTPOL | SS | Functional Descriptions                      |
|----------|----|----------------------------------------------|
| 0        | 0  | SPIM_SS is active low, and set SPIM_SS to 0  |
| 0        | 1  | SPIM_SS is active low, and set SPIM_SS to 1  |
| 1        | 0  | SPIM_SS is active high, and set SPIM_SS to 1 |
| 1        | 1  | SPIM_SS is active high, and set SPIM_SS to 0 |

Table 6.21-2 Function Description for Slave Select Active Level and Slave Active Enable

**RX Clock Delay Control Register (SPIM\_RXCLKDLY)**

| Register      | Offset       | R/W | Description                     |  |  | Reset Value |
|---------------|--------------|-----|---------------------------------|--|--|-------------|
| SPIM_RXCLKDLY | SPIM_BA+0x0C | R/W | RX Clock Delay Control Register |  |  | 0x0000_010F |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [20]    | RDEdge      | <b>Sampling Clock Edge Selection for Received Data (for Normal I/O Mode, DMA Read Mode, DMA Write Mode, and Direct Memory Mapping Mode)</b><br>0 = Use SPI input clock rising edge to sample received data. (Default)<br>1 = Use SPI input clock falling edge to sample received data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [19]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [18:16] | RDDLYSEL    | <b>Sampling Clock Delay Selection for Received Data (for Normal I/O Mode, DMA Read Mode, DMA Write Mode, and Direct Memory Mapping Mode)</b><br>Determine the number of inserted delay cycles. Used to adjust the sampling clock of received data to latch the correct data.<br>0x0: No delay. (Default)<br>0x1: Delay 1 SPI Flash clock.<br>0x2: Delay 2 SPI Flash clocks.<br>0x3: Delay 3 SPI Flash clocks.<br>...<br>0x7: Delay 7 SPI Flash clocks<br><b>Note:</b> The manufacturer or device ID of external SPI Flash component can be used to determine the correct setting value of RDDLYSEL. An example is given as follows.<br>For example, the manufacturer ID and device ID of external SPI Flash for some vendor are 0xEF and 0x1234 separately. First, set RDDLYSEL to 0x0, and use read manufacturer id/device id command to read the manufacturer id of external SPI Flash by using normal I/O mode (the manufacturer id is 0xEF (1110_1111) in this example).<br>If the manufacturer ID which reads from external SPI Flash is 0xF7 (1111_0111), it denotes that manufacturer id is shifted the right by 1 bit and most significant bit (MSB) of manufacturer id is assigned to 1. According to manufacturer id reads from external SPI Flash, RDDLYSEL needs to be set to 0x1 to receive SPI Flash data correctly. |
| [15:8]  | PHDELSEL    | <b>SPI Flash Phase Delay Time (for DMA Write Mode, DMA Read Mode)</b><br>The bits set phase delay time between command data phase, address data phase, and dummy cycle phase, where SPI Flash controller will send those phase data to external SPI Flash.<br>Phase delay time of DMA write mode and DMA read mode = (PHDELSEL + 1) * AHB clock cycle time ( <b>Note</b> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|       |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | <p><b>Note:</b> AHB clock cycle time = 1/AHB clock frequency.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [7:0] | DWDELSEL | <p><b>SPI Flash Deselect Time Interval of DMA Write Mode (for DMA Write Mode Only)</b><br/>The bits set the deselect time interval of SPI Flash (i.e. time interval of inactive level of SPIM_SS) when SPI Flash controller operates on DMA write mode. <b>(Note1)</b><br/>Deselect time interval of DMA write mode = (DWDELSEL + 1) * AHB clock cycle time <b>(Note2)</b>.<br/><b>Note1:</b> Please check the used external SPI Flash component to set this register value. In general case, the deselect time interval of SPI Flash is greater than 50 ns when SPI Flash performs the program operation.<br/><b>Note2:</b> AHB clock cycle time = 1/AHB clock frequency.</p> |

**Data Receive Register 0~3 (SPIM\_RX0~3)**

| Register        | Offset       | R/W | Description             |  |  | Reset Value |
|-----------------|--------------|-----|-------------------------|--|--|-------------|
| <b>SPIM_RX0</b> | SPIM_BA+0x10 | R   | Data Receive Register 0 |  |  | 0x0000_0000 |
| <b>SPIM_RX1</b> | SPIM_BA+0x14 | R   | Data Receive Register 1 |  |  | 0x0000_0000 |
| <b>SPIM_RX2</b> | SPIM_BA+0x18 | R   | Data Receive Register 2 |  |  | 0x0000_0000 |
| <b>SPIM_RX3</b> | SPIM_BA+0x1C | R   | Data Receive Register 3 |  |  | 0x0000_0000 |



| Bits   | Description  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>RXDAT</b> | <p><b>Data Receive Register</b></p> <p>The Data Receive Registers hold the received data of the last executed transfer.</p> <p>Number of valid RX registers is specified in SPIM_CTL0[BURSTNUM]. If BURSTNUM &gt; 0, received data are held in the most significant RXDAT register first.</p> <p>Number of valid-bit is specified in SPIM_CTL0[DWIDTH]. If DWIDTH is 16, 24, or 32, received data are held in the least significant byte of RXDAT register first.</p> <p>In a byte, received data are held in the most significant bit of RXDAT register first.</p> <p><b>Example1:</b> If SPIM_CTL0[BURSTNUM] = 0x3 and SPIM_CTL1[DWIDTH] = 0x17, received data will be held in the order SPIM_RX3[23:0], SPIM_RX2[23:0], SPIM_RX1[23:0], SPIM_RX0[23:0].</p> <p><b>Example2:</b> If SPIM_CTL0[BURSTNUM] = 0x0 and SPIM_CTL0[DWIDTH] = 0x17, received data will be held in the order SPIM_RX0[7:0], SPIM_RX0[15:8], SPIM_RX0[23:16].</p> <p><b>Example3:</b> If SPIM_CTL0[BURSTNUM] = 0x0 and SPIM_CTL0[DWIDTH] = 0x07, received data will be held in the order SPIM_RX0[7], SPIM_RX0[6], ...., SPIM_RX0[0].</p> |

**Data Transmit Register 0~3 (SPIM\_TX0~3)**

| Register        | Offset       | R/W | Description              |  |  | Reset Value |
|-----------------|--------------|-----|--------------------------|--|--|-------------|
| <b>SPIM_TX0</b> | SPIM_BA+0x20 | R/W | Data Transmit Register 0 |  |  | 0x0000_0000 |
| <b>SPIM_TX1</b> | SPIM_BA+0x24 | R/W | Data Transmit Register 1 |  |  | 0x0000_0000 |
| <b>SPIM_TX2</b> | SPIM_BA+0x28 | R/W | Data Transmit Register 2 |  |  | 0x0000_0000 |
| <b>SPIM_TX3</b> | SPIM_BA+0x2C | R/W | Data Transmit Register 3 |  |  | 0x0000_0000 |



| Bits   | Description  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>TXDAT</b> | <p><b>Data Transmit Register</b></p> <p>The Data Transmit Registers hold the data to be transmitted in next transfer.</p> <p>Number of valid TXDAT registers is specified in SPIM_CTL0[BURSTNUM]. If BURSTNUM &gt; 0, data are transmitted in the most significant TXDAT register first.</p> <p>Number of valid-bit is specified in SPIM_CTL0[DWIDTH]. If DWIDTH is 16, 24, or 32, data are transmitted in the least significant byte of TXDAT register first.</p> <p>In a byte, data are transmitted in the most significant bit of TXDAT register first.</p> <p><b>Example1:</b> If SPIM_CTL0[BURSTNUM] = 0x3 and SPIM_CTL1[DWIDTH] = 0x17, data will be transmitted in the order SPIM_TX3[23:0], SPIM_TX2[23:0], SPIM_TX1[23:0], SPIM_TX0[23:0] in next transfer.</p> <p><b>Example2:</b> If SPIM_CTL0[BURSTNUM] = 0x0 and SPIM_CTL0[DWIDTH] = 0x17, data will be transmitted in the order SPIM_TX0[7:0], SPIM_TX0[15:8], SPIM_TX0[23:16] in next transfer.</p> <p><b>Example3:</b> If SPIM_CTL0[BURSTNUM] = 0x0 and SPIM_CTL0[DWIDTH] = 0x07, data will be transmitted in the order SPIM_TX0[7], SPIM_TX0[6], ..., SPIM_TX0[0] in next transfer.</p> |

**SRAM Memory Address Register (SPIM\_SRAMADDR)**

| Register      | Offset       | R/W | Description                  |  |  |  | Reset Value |
|---------------|--------------|-----|------------------------------|--|--|--|-------------|
| SPIM_SRAMADDR | SPIM_BA+0x30 | R/W | SRAM Memory Address Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                              |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | ADDR        | <p><b>SRAM Memory Address</b></p> <p>For DMA Read mode, this is the destination address for DMA transfer.</p> <p>For DMA Write mode, this is the source address for DMA transfer.</p> <p><b>Note:</b> This address must be word-aligned.</p> |

**DMA Transfer Byte Count Register (SPIM\_DMACNT)**

| Register    | Offset       | R/W | Description                      |  |  |  | Reset Value |
|-------------|--------------|-----|----------------------------------|--|--|--|-------------|
| SPIM_DMACNT | SPIM_BA+0x34 | R/W | DMA Transfer Byte Count Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                     |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                           |
| [23:0]  | <b>DMACNT</b>   | <p><b>DMA Transfer Byte Count Register</b><br/> It indicates the transfer length for DMA process.</p> <p><b>Note1:</b> The unit for counting is byte.</p> <p><b>Note2:</b> The number must be the multiple of 4.</p> <p><b>Note3:</b> Please check specification of used SPI Flash to know maximum byte length of page program.</p> |

**SPI Flash Address Register (SPIM\_FADDR)**

| Register   | Offset       | R/W | Description                |  |  |  | Reset Value |
|------------|--------------|-----|----------------------------|--|--|--|-------------|
| SPIM_FADDR | SPIM_BA+0x38 | R/W | SPI Flash Address Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | ADDR        | <p><b>SPI Flash Address Register</b></p> <p>For DMA Read mode, this is the source address for DMA transfer.</p> <p>For DMA Write mode, this is the destination address for DMA transfer.</p> <p><b>Note1:</b> This address must be word-aligned.</p> <p><b>Note2:</b> For external SPI Flash with 32 MB, the value of this SPI Flash address register "ADDR" is from 0x00000000 to 0x01FFFFFF when using DMA write mode and DMA read mode to write/read external SPI Flash data. Please user check size of used SPI Flash component to know access address range of external SPI Flash.</p> |

**Cipher Key1 Register (SPIM\_KEY1)**

| Register  | Offset       | R/W | Description          |  |  |  | Reset Value |
|-----------|--------------|-----|----------------------|--|--|--|-------------|
| SPIM_KEY1 | SPIM_BA+0x3C | W   | Cipher Key1 Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | KEY1        | <p><b>Cipher Key1 Register</b></p> <p>This is the KEY1 data for cipher function.</p> <p><b>Note1:</b> If there is not any KEY1(SPIM_KEY1[31:0]) or KEY2(SPIM_KEY2[31:0]) (KEY1 is 0x0000_0000 or KEY2 is 0x0000_0000), the cipher function will be disabled automatically.</p> <p><b>Note2:</b> When CIPHOFF(SPIM_CTL0[0]) is 0, both of KEY1(SPIM_KEY1[31:0]) and KEY2(SPIM_KEY2[31:0]) do not equal to 0x0000_0000 (i.e. KEY1≠ 0x0000_0000 and KEY2≠ 0x0000_0000), cipher encryption/decryption is enabled.</p> |

**Cipher Key2 Register (SPIM\_KEY2)**

| Register  | Offset       | R/W | Description          |  |  |  | Reset Value |
|-----------|--------------|-----|----------------------|--|--|--|-------------|
| SPIM_KEY2 | SPIM_BA+0x40 | W   | Cipher Key2 Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | KEY2        | <p><b>Cipher Key2 Register</b></p> <p>This is the KEY2 data for cipher function.</p> <p><b>Note1:</b> If there is not any KEY1(SPIM_KEY1[31:0]) or KEY2(SPIM_KEY2[31:0]) (KEY1 is 0x0000_0000 or KEY2 is 0x0000_0000), the cipher function will be disabled automatically.</p> <p><b>Note2:</b> When CIPHOFF(SPIM_CTL0[0]) is 0, both of KEY1(SPIM_KEY1[31:0]) and KEY2(SPIM_KEY2[31:0]) do not equal to 0x0000_0000 (i.e. KEY1≠ 0x0000_0000 and KEY2≠ 0x0000_0000), cipher encryption/decryption is enabled.</p> |

Direct Memory Mapping Mode Control Register (SPIM\_DMMCTL)

| Register    | Offset       | R/W | Description                                 |  |  |  | Reset Value |
|-------------|--------------|-----|---------------------------------------------|--|--|--|-------------|
| SPIM_DMMCTL | SPIM_BA+0x44 | R/W | Direct Memory Mapping Mode Control Register |  |  |  | 0x0008_0000 |

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

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | <b>ACTSCLKT</b><br><br>SPI Flash Active SCLK Time (Only for Direct Memory Mapping Mode, DMA Write Mode, and DMA Read Mode)<br><br>The bits set time interval between SPIM SS active edge and the position edge of the first serial SPI output clock, as shown in Figure 6.21-11.<br><br>(1) ACTSCLKT = 0 (function disable):<br>Time interval = 1 AHB clock cycle time.<br>(2) ACTSCLKT ≠ 0 (function enable):<br>Time interval = (ACTSCLKT + 3) * AHB clock cycle time.<br><b>Note1:</b> AHB clock cycle time = 1/AHB clock frequency.<br><b>Note2:</b> SCLK is SPI output clock<br><b>Note3:</b> Please check the used SPI Flash specification to know the setting value of this register, and different SPI Flash vendor may use different setting values.                                                                                                                                                                     |
| [27]    | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [26]    | <b>UACTSCLK</b><br><br>User Sets SPI Flash Active SCLK Time (Only for Direct Memory Mapping Mode, DMA Write Mode, and DMA Read Mode)<br><br>0 = According to DIVIDER(SPIM_CTL1[31:16]), ACTSCLKT(SPIM_DMMCTL[31:28]) is set by hardware automatically. (Default)<br>1 = Set ACTSCLKT(SPIM_DMMCTL[31:28]) by user manually.<br><b>Note:</b> When user wants to set ACTSCLKT(SPIM_DMMCTL[31:28]) manually, please set UACTSCLK to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [25]    | <b>CREN</b><br><br>Continuous Read Mode Enable Bit (Only for Direct Memory Mapping Mode, Read Command Codes 0xBB, 0xEB, 0xE7, 0x0D, 0xBD, 0xED)<br><br>0 = Continuous Read Mode Disabled. (Default)<br>1 = Continuous Read Mode Enabled.<br><br>For read operations of SPI Flash, commands of fast read quad I/O (0xEB), word read quad I/O (0xE7), fast read dual I/O (0xBB), DTR/DDR fast read (0x0D), DTR/DDR fast read dual I/O (0xBD), and DTR/DDR fast read quad I/O (0xED) can further reduce command overhead through setting the “continuous read mode” bits (8 bits) after the input address data.<br><br><b>Note:</b> When using function of continuous read mode and setting USETEN (SPIM_CTL2[16]) to 1, CRMDAT(SPIM_DMMCTL[15:8]) must be set by used SPI Flash specifications. When using function of continuous read mode and setting USETEN(SPIM_CTL2[16]) to 0, CRMDAT(SPIM_DMMCTL[15:8]) is set to value 0x20. |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                 | <b>16 Bytes Burst Wrap Mode Enable Bit (Only for Direct Memory Mapping Mode, Cache Enable, and Read Command Code “0xEB, and 0xE7”)</b><br>0 = Burst Wrap Mode Disabled. (Default)<br>1 = Burst Wrap Mode Enabled.<br><br>In direct memory mapping mode, both of quad read commands “0xEB” and “0xE7” support burst wrap mode for cache application and performance enhance. For cache application, the burst wrap mode can be used to fill the cache line quickly (In this SPI Flash controller, use cache data line with 16 bytes size). For performance enhance with direct memory mapping mode and cache enable, when cache data is miss, the burst wrap mode can let MCU get the required SPI Flash data quickly.                                                                                                                                                                |
| [24]    | <b>BWEN</b>     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [23:21] | <b>Reserved</b> | <b>SPI Flash Deselect Time (Only for Direct Memory Mapping Mode)</b><br>Set the minimum time width of SPI Flash deselect time (i.e. Minimum SPIM_SS deselect time), as shown in Figure 6.21-11.<br>(1) Cache function disable:<br>Minimum time width of SPIM_SS deselect time = (DESELTIM + 1) * AHB clock cycle time.<br>(2) Cache function enable:<br>Minimum time width of SPIM_SS deselect time = (DESELTIM + 4) * AHB clock cycle time.<br><b>Note1:</b> AHB clock cycle time = 1/AHB clock frequency.<br><b>Note2:</b> When cipher encryption/decryption is enabled, please set this register value >= 0x10. When cipher encryption/decryption is disabled, please set this register value >= 0x8.<br><b>Note3:</b> Please check the used SPI Flash specification to know the setting value of this register, and different SPI Flash vendor may use different setting values. |
| [20:16] | <b>DESELTIM</b> | <b>Mode Bits Data for Continuous Read Mode (or Performance Enhance Mode) (Only for Direct Memory Mapping Mode)</b><br>Set the mode bits data for continuous read mode (or performance enhance mode).<br>When setting this mode bits currently ( <b>Note1</b> ) and set CREN(SPIM_DMMCTL[25]), this reduces the command phase by eight clocks and allows the read address to be immediately entered after SPIM_SS asserted to active. ( <b>Note1</b> )<br><b>Note1:</b> Please check the used SPI Flash specification to know the setting value of this mode bits data, and different SPI Flash vendor may use different setting values.<br><b>Note2:</b> CRMDAT needs to be used with CREN(SPIM_DMMCTL[25]).                                                                                                                                                                         |
| [15:8]  | <b>CRMDAT</b>   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [7:0]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



Figure 6.21-11 SPIM\_SS Active Setup Time Relative to SPIM\_CLK, and SPIM\_SS Deselect Time

Control Register 2 (SPIM\_CTL2)

| Register  | Offset       | R/W | Description        |  |  |  | Reset Value |
|-----------|--------------|-----|--------------------|--|--|--|-------------|
| SPIM_CTL2 | SPIM_BA+0x48 | R/W | Control Register 2 |  |  |  | 0x0804_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [28:24] | DCNUM       | <p><b>Dummy Cycle Number (Only for Direct Memory Mapping Mode and DMA Read Mode)</b><br/>Set number of dummy cycles</p> <p><b>(1) For non-DTR/non-DDR command codes 0x03, 0x0B, 0x3B, 0xBB, 0xEB, and 0xE7:</b><br/>When read command code do not need any dummy cycles (i.e. dummy cycle number = 0x0), user must set DCNUM to 0x0.</p> <p>For command code 0xBB, if both mode cycle number (or performance enhance cycle number) and dummy cycle number do not equal to 0x0 simultaneously, user must set DCNUM to "mode cycle number + dummy cycle number" by used SPI Flash specification.</p> <p>For command code 0xBB, if there is only dummy cycle number (i.e. dummy cycle number ≠ 0x0 and mode cycle number = 0x0 (or performance enhance cycle number = 0x0)), user set DCNUM to dummy cycle number by used SPI Flash specification.</p> <p>For command codes 0x0B, 0x3B, 0xEB, and 0xE7, user only set DCNUM to dummy cycle number by used SPI Flash specification.</p> <p><b>(2) For DTR/DDR command codes 0x0D, 0xBD, and 0xED:</b><br/>user sets DCNUM to dummy cycle number and DTRMPOFF(SPIM_CTL2[20]) by used SPI Flash specification.</p> <p><b>Note:</b> Number of dummy cycles depends on the frequency of SPI output clock, SPI Flash vendor, and read command types. Please check the used SPI Flash specification to know the setting value of this number of dummy cycles.</p> |
| [23:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [20]    | DTRMPOFF    | <p><b>Mode Phase OFF for DTR/DDR Command Codes 0x0D, 0xBD, and 0xED (Only for Direct Memory Mapping Mode and DMA Read Mode)</b><br/>0 = Mode cycle number (or performance enhance cycle number) does not equal to 0x0 in DTR/DDR read command codes 0x0D, 0xBD, and 0xED.<br/>1 = mode cycle number (or performance enhance cycle number) equals to 0x0 in DTR/DDR read command codes 0x0D, 0xBD, and 0xED.</p> <p><b>Note:</b> Please check the used SPI Flash specification to know the mode cycle number (or performance enhance cycle number) for DTR/DDR command codes 0x0D, 0xBD, and 0xED.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [19:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|        |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                 | <p><b>User Set Value Enable Bit (Only for Direct Memory Mapping Mode and DMA Read Mode with Read Commands 0x03,0x0B,0x3B,0xBB,0xEB,0xE7)</b></p> <p>0 = Hardware circuit of SPI Flash controller will use the following default values of DCNUM(SPIM_CTL2[28:24]) and CRMDAT(SPIM_DMMCTL[15:8]) to configure SPI Flash operations automatically.</p> <p><b>Dummy cycle number (DCNUM):</b></p> <p>Dummy cycle number for read command 0x03: 0x0<br/>Dummy cycle number for read command 0x0B: 0x8<br/>Dummy cycle number for read command 0x3B: 0x8<br/>Dummy cycle number for read command 0xBB: 0x0<br/>Dummy cycle number for read command 0xEB: 0x4<br/>Dummy cycle number for read command 0xE7: 0x2<br/>Mode bits data for continuous read mode (CRMDAT): 0x20</p> <p>1 = If DCNUM(SPIM_CTL2[28:24]) and CRMDAT(SPIM_DMMCTL[15:8]) are not set as above default values, user must set USETEN to 0x1, DCNUM(SPIM_CTL2[28:24]) and CRMDAT(SPIM_DMMCTL[15:8]) to configure SPI Flash operations manually.</p> <p>For DTR/DDR command codes 0x0D, 0xBD, and 0xED, please set USETEN to 0x1.</p> |
| [15:0] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

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

### 6.22.1 Overview

I<sup>2</sup>C is a two-wire, bi-directional serial bus that provides a simple and efficient method of data exchange between devices. The I<sup>2</sup>C standard is a true multi-master bus including collision detection and arbitration that prevents data corruption if two or more masters attempt to control the bus simultaneously.

There are two sets of I<sup>2</sup>C controllers which support Power-down wake-up function.

### 6.22.2 Features

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

- Supports up to three I<sup>2</sup>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 I<sup>2</sup>C interrupt if the I<sup>2</sup>C bus hangs up and timer-out counter overflows
- Programmable clocks allow for versatile rate control
- Supports 7-bit addressing 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.22.3 Block Diagram



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

### 6.22.4 Basic Configuration

#### 6.22.4.1 I<sup>2</sup>C0 basic configurations

- Clock source Configuration
  - Enable I<sup>2</sup>C0 peripheral clock in I<sup>2</sup>C0CKEN (CLK\_APBCLK0[8]).
- Reset Configuration
  - Reset I<sup>2</sup>C0 controller in I<sup>2</sup>C0RST (SYS\_IPRST1[8]).
- Pin configuration

| Group             | Pin Name                 | GPIO                           | MFP  |
|-------------------|--------------------------|--------------------------------|------|
| I <sup>2</sup> C0 | I <sup>2</sup> C0_SCL    | PC.12, PD.7, PE.13, PF.3, PG.0 | MFP4 |
|                   |                          | PB.5, PH.2                     | MFP6 |
|                   |                          | PA.5, PC.1                     | MFP9 |
|                   | I <sup>2</sup> C0_SDA    | PC.8, PC.11, PD.6, PF.2, PG.1  | MFP4 |
|                   |                          | PB.4, PH.3                     | MFP6 |
|                   |                          | PA.4, PC.0                     | MFP9 |
|                   | I <sup>2</sup> C0_SMBAL  | PG.2                           | MFP4 |
|                   |                          | PC.3                           | MFP9 |
|                   | I <sup>2</sup> C0_SMBSUS | PG.3                           | MFP4 |
|                   |                          | PC.2                           | MFP9 |
|                   |                          | PA.15, PD.0                    | MFP6 |

|  |  |            |      |
|--|--|------------|------|
|  |  | PA.10      | MFP7 |
|  |  | PB.12      | MFP8 |
|  |  | PA.0, PH.9 | MFP9 |

#### 6.22.4.2 I2C1 Basic Configurations

- Clock Source Configuration
  - Enable I2C1 peripheral clock in I2C1CKEN (CLK\_APBCLK0[9]).
- Reset Configuration
  - Reset I2C1 controller in I2C1RST (SYS\_IPRST1[9]).
- Pin Configuration

| Group | Pin Name    | GPIO             | MFP  |
|-------|-------------|------------------|------|
| I2C1  | I2C1_SCL    | PF.0             | MFP3 |
|       |             | PA.12, PD.5      | MFP4 |
|       |             | PG.2             | MFP5 |
|       |             | PB.11            | MFP7 |
|       |             | PA.7, PE.1       | MFP8 |
|       |             | PA.3, PB.1, PC.5 | MFP9 |
|       | I2C1_SDA    | PF.1             | MFP3 |
|       |             | PA.13, PD.4      | MFP4 |
|       |             | PG.3             | MFP5 |
|       |             | PB.10            | MFP7 |
|       |             | PA.6, PE.0       | MFP8 |
|       |             | PA.2, PB.0, PC.4 | MFP9 |
|       | I2C1_SMBAL  | PG.0             | MFP5 |
|       |             | PB.9             | MFP7 |
|       |             | PC.7, PH.8       | MFP8 |
|       | I2C1_SMBSUS | PG.1             | MFP5 |
|       |             | PB.8             | MFP7 |
|       |             | PC.6, PH.9       | MFP8 |

#### 6.22.4.3 I2C2 Basic Configurations

- Clock source Configuration
  - Enable I2C2 peripheral clock in I2C2CKEN (CLK\_APBCLK0[10]).
- Reset Configuration
  - Reset I2C2 controller in I2C2RST (SYS\_IPRST1[10]).
- Pin Configuration

| Group | Pin Name | GPIO | MFP |
|-------|----------|------|-----|
|       |          |      |     |

|      |             |             |      |
|------|-------------|-------------|------|
| I2C2 | I2C2_SCL    | PD.9        | MFP3 |
|      |             | PA.14, PD.1 | MFP6 |
|      |             | PA.11       | MFP7 |
|      |             | PB.13       | MFP8 |
|      |             | PA.1, PH.8  | MFP9 |
|      | I2C2_SDA    | PD.8        | MFP3 |
|      |             | PA.15, PD.0 | MFP6 |
|      |             | PA.10       | MFP7 |
|      |             | PB.12       | MFP8 |
|      |             | PA.0, PH.9  | MFP9 |
|      | I2C2_SMBAL  | PB.15       | MFP8 |
|      | I2C2_SMBSUS | PB.14       | MFP8 |

### **6.22.5 Functional Description**

On I<sup>2</sup>C bus, data is transferred between a Master and a Slave. Data bits transfer on the SCL and SDA lines are synchronously on a byte-by-byte basis. Each data byte is 8-bit long. There is one SCL clock pulse for each data bit with the MSB being transmitted first, and an acknowledge bit follows each transferred byte. Each bit is sampled during the high period of SCL; therefore, the SDA line may be changed only during the low period of SCL and must be held stable during the high period of SCL. A transition on the SDA line while SCL is high is interpreted as a command (START or STOP). Please refer to Figure 6.22-2 for more detailed I<sup>2</sup>C BUS Timing.



Figure 6.22-2 I<sup>2</sup>C Bus Timing

The device's on-chip I<sup>2</sup>C provides the serial interface that meets the I<sup>2</sup>C bus standard mode specification. The I<sup>2</sup>C port handles byte transfers autonomously. To enable this port, the bit I2CEN in I2C\_CTL0 should be set to '1'. The I<sup>2</sup>C hardware interfaces to the I<sup>2</sup>C bus via two pins: SDA and SCL. When I/O pins are used as I<sup>2</sup>C ports, user must set the pins function to I<sup>2</sup>C in advance.

**Note:** Pull-up resistor is needed for I<sup>2</sup>C operation as the SDA and SCL are open-drain pins.

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

Figure 6.22-3 shows the typical I<sup>2</sup>C protocol. Normally, a standard communication consists of four parts:

- START or Repeated START signal generation
  - Slave address and R/W bit transfer
  - Data transfer

- STOP signal generation

Figure 6.22-3 I<sup>2</sup>C Protocol

- START or Repeated START signal

When the bus is free/idle, which means no master device is engaging the bus (both SCL and SDA lines are high), a master can initiate a transfer by sending a START signal. A START signal, usually referred to as the "S" bit, is defined as a HIGH to LOW transition on the SDA line while SCL is HIGH. The START signal denotes the beginning of a new data transmission.

After having sent the address byte (address and read/write bit), the master may send any number of bytes followed by a stop condition. Instead of sending the stop condition it is also allowed to send another start condition again followed by an address (and of course including a read/write bit) and more data. The start condition is called as Repeat START (Sr). This is defined recursively allowing any number of start conditions to be sent. The purpose of this is to allow combined write/read operations to one or more devices without releasing the bus and thus with the guarantee that the operation is not interrupted. The controller uses this method to communicate with another slave or the same slave in a different transfer direction (e.g. from writing to a device to reading from a device) without releasing the bus.

- STOP signal

The master can terminate the communication by generating a STOP signal. A STOP signal, usually referred to as the "P" bit, is defined as a LOW to HIGH transition on the SDA line while SCL is HIGH.

Figure 6.22-4 shows the waveform of START, Repeat START and STOP.



Figure 6.22-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.22-5 and Figure 6.22-6 shows the waveform of bit transfer and acknowledge.



Figure 6.22-5 Bit Transfer on the I<sup>2</sup>C Bus



Figure 6.22-6 Acknowledge on the I<sup>2</sup>C Bus

- Data transfer on I<sup>2</sup>C bus

Figure 6.22-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.22-7 Master Transmits Data to Slave by 7-bit

Figure 6.22-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.22-8 Master Reads Data from Slave by 7-bit

Figure 6.22-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.22-9 Master Transmits Data to Slave by 10-bit

Figure 6.22-10 shows a master read data from slave by 10-bit. A master addresses a slave with a 10-bit address. First master transmits 10-bit address to slave, after that master transmits first byte with read index. The slave will start transmitting data after the first byte with read index.



Figure 6.22-10 Master Reads Data from Slave by 10-bit

#### 6.22.5.2 Operation Modes

The on-chip I<sup>2</sup>C ports support three operation modes, Master, Slave, and General Call Mode.

In a given application, I<sup>2</sup>C port may operate as a master or as a slave. In Slave mode, the I<sup>2</sup>C port hardware looks for its own slave address and the general call address. If one of these addresses is detected, and if the slave is willing to receive or transmit data from/to master(by setting the AA bit), acknowledge pulse will be transmitted out on the 9th clock, hence an interrupt is requested on both master and slave devices if interrupt is enabled. When the microcontroller wishes to become the bus master, hardware waits until the bus is free before entering Master mode so that a possible slave action is not be interrupted. If bus arbitration is lost in Master mode, I<sup>2</sup>C port switches to Slave mode immediately and can detect its own slave address in the same serial transfer.

To control the I<sup>2</sup>C bus transfer in each mode, user needs to set I2C\_CTL0, I2C\_DAT registers according to current status code of I2C\_STATUS0 register. In other words, for each I<sup>2</sup>C bus action, user needs to check current status by I2C\_STATUS0 register, and then set I2C\_CTL0, I2C\_DAT registers to take bus action. Finally, check the response status by I2C\_STATUS0.

The bits, STA, STO and AA in I2C\_CTL0 register are used to control the next state of the I<sup>2</sup>C hardware after SI flag of I2C\_CTL0 [3] register is cleared. Upon completion of the new action, a new status code will be updated in I2C\_STATUS0 register and the SI flag of I2C\_CTL0 register will be set. But the SI flag will not be set when I<sup>2</sup>C STOP. If the I<sup>2</sup>C interrupt control bit INTEN (I2C\_CTL0 [7]) is set, appropriate action or software branch of the new status code can be performed in the Interrupt service routine.

Figure 6.22-11 shows the current I<sup>2</sup>C status code is 0x08, and then set I2C\_DATA=SLA+W and (STA,STO,SI,AA) = (0,0,1,x) to send the address to I<sup>2</sup>C bus. If a slave on the bus matches the address and response ACK, the I2C\_STATUS0 will be updated by status code 0x18.

Figure 6.22-11 Control I<sup>2</sup>C Bus according to the Current I<sup>2</sup>C Status

#### Master Mode

In Figure 6.22-12 and Figure 6.22-13, all possible protocols for I<sup>2</sup>C master are shown. User needs to follow proper path of the flow to implement required I<sup>2</sup>C protocol.

In other words, user can send a START signal to bus and I<sup>2</sup>C will be in Master Transmitter (MT) mode

(Figure 6.22-12) or Master receiver (MR) mode (Figure 6.22-13) after START signal has been sent successfully and new status code would be 0x08. Followed by START signal, user can send slave address, read/write bit, data and Repeat START, STOP to perform I<sup>2</sup>C protocol.



Figure 6.22-12 Master Transmitter Mode Control Flow



Figure 6.22-13 Master Receiver Mode Control Flow

If the I<sup>2</sup>C is in Master mode and gets arbitration lost, the status code will be 0x38. In status 0x38, user may set (STA, STO, SI, AA) = (1, 0, 1, X) to send START to re-start Master operation when bus become free. Otherwise, user may set (STA, STO, SI, AA) = (0, 0, 1, X) to release I<sup>2</sup>C bus and enter not addressed Slave mode.

## Slave Mode

When reset default, I<sup>2</sup>C is not addressed and will not recognize the address on I<sup>2</sup>C bus. User can set slave address by I2C\_ADDRn (n=0~3) and set (STA, STO, SI, AA) = (0, 0, 1, 1) to let I<sup>2</sup>C recognize the address sent by master. Figure 6.22-14 shows all the possible flow for I<sup>2</sup>C in Slave mode. Users need to follow a proper flow (as shown in Figure 6.22-14 to implement their own I<sup>2</sup>C protocol.

If bus arbitration is lost in Master mode, I<sup>2</sup>C port switches to Slave mode immediately and can detect its own slave address in the same serial transfer. If the detected address is SLA+W (Master want to write data to Slave) after arbitration lost, the status code is 0x68. If the detected address is SLA+R (Master want to read data from Slave) after arbitration lost, the status code is 0xB0.

**Note:** During I<sup>2</sup>C communication, the SCL clock will be released when writing '1' to clear SI flag in Slave mode.



Figure 6.22-14 Slave Mode Control Flow

If I<sup>2</sup>C is still receiving data in addressed Slave mode but got a STOP or Repeat START, the status code will be 0xA0. User could follow the action for status code 0x88 as shown in the above figure when getting 0xA0 status.

If I<sup>2</sup>C is still transmitting data in addressed Slave mode but got a STOP or Repeat START, the status code will be 0xA0. User could follow the action for status code 0xC8 as shown in the above figure when getting 0xA0 status.

**Note:** After slave gets status of 0x88, 0xC8, 0xC0 and 0xA0, slave can switch to not address mode and own SLA will not be recognized. If entering this status, slave will not receive any I<sup>2</sup>C signal or address from master. At this status, I<sup>2</sup>C should enter idle mode.

### General Call (GC) Mode

If the GC bit (I<sup>2</sup>C\_ADDRn [0]) is set, the I<sup>2</sup>C port hardware will respond to General Call address (00H). User can clear GC bit to disable general call function. When the GC bit is set and the I<sup>2</sup>C in Slave mode, it can receive the general call address by 0x00 after master send general call address to I<sup>2</sup>C bus, then it will follow status of GC mode.

The GC mode can wake up when address matched. Note that the default address is 0x00, but user must set an address except for 0x00.



Figure 6.22-15 GC Mode

If I<sup>2</sup>C is still receiving data in GC mode but got a STOP or Repeat START, the status code will be 0xA0. User could follow the action for status code 0x98 in above figure when getting 0xA0 status.

**Note:** After slave gets status of 0x98 and 0xA0, slave can switch to not address mode and own SLA will not be recognized. If entering this status, slave will not receive any I<sup>2</sup>C signal or address from master. At this time, the I<sup>2</sup>C controller should enter idle mode.

#### Multi-Master

In some applications, there are two or more masters on the same I<sup>2</sup>C bus to access slaves, and the masters may transmit data simultaneously. The I<sup>2</sup>C supports multi-master by including collision detection and arbitration to prevent data corruption.

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.22-16 Arbitration Lost

- When I2C\_STATUS0 = 0x38, an “Arbitration Lost” is received. Arbitration lost event maybe occur during the send START bit, data bits or STOP bit. User could set (STA, STO, SI, AA) = (1, 0, 1, X) to send START again when bus free, or set (STA, STO, SI, AA) = (0, 0, 1, X) to not addressed Slave mode. User can detect bus free by ONBUSY (I2C\_STATUS1 [8]).
- When I2C\_STATUS0 = 0x00, a “Bus Error” is received. To recover I<sup>2</sup>C bus from a bus error, STO should be set and SI should be cleared, and then STO is cleared to release bus.
  - Set (STA, STO, SI, AA) = (0, 1, 1, X) to stop current transfer
  - Set (STA, STO, SI, AA) = (0, 0, 1, X) to release bus

### Bus Management (SMBus/PMBus Compatiable)

This section is relevant only when Bus Management feature is supported.

#### Introduction

The Bus Management is an I<sup>2</sup>C interface through which various devices can communicate with each other and with the rest of the system. It is based on I<sup>2</sup>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 I<sup>2</sup>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<br>Bits 7-1 | R/W Bit<br>Bit 0 | Comment                                   |
|---------------------------|------------------|-------------------------------------------|
| 0000 000                  | 0                | General Call Address                      |
| 0000 000                  | 1                | START byte                                |
| 0000 001                  | X                | CBUS address                              |
| 0000 010                  | X                | Address reserved for different bus format |
| 0000 011                  | X                | Reserved for future use                   |
| 0000 1XX                  | X                | Reserved for future use                   |
| 0101 000                  | X                | Reserved for ACCESS.bus host              |
| 0110 111                  | X                | Reserved for ACCESS.bus default address   |
| 1111 0XX                  | X                | 10-bit slave addressing                   |
| 1111 1XX                  | X                | Reserved for future use                   |
| 0001 000                  | X                | SMBus Host                                |
| 0001 100                  | X                | SMBus Alert Response Address              |
| 1100 001                  | X                | SMBus Device Default Address              |

Table 6.22-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.22-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.22-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.22-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.22-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  $C(x) = 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}} = (\text{BUSTO}(\text{I2C_BUSTOUT}[7:0]) + 1) \times 16 \times 1024 \text{ (14-bit)} \times T_{\text{PCLK}} \text{ (if TOCDIV4 = 0).}$$

$$= (\text{BUSTO}(\text{I2C_BUSTOUT}[7:0]) + 1) \times 16 \times 1024 \text{ (14-bit)} \times 4 \times T_{\text{PCLK}} \text{ (if TOCDIV4 = 1)}$$

The bus idle condition (both SCLK and SDA high) when bus IDLE

$$T_{\text{Time-out}} = (\text{BUSTO}(\text{I2C_BUSTOUT}[7:0]) + 1) \times 4 \times T_{\text{PCLK}}.$$



Figure 6.22-21 Bus Management Time Out Timing

**Bus Clock Low Time-out:**

In Master mode, the Master cumulative clock low extend time ( $T_{\text{LOW:MEXT}}$ ) is detected

In Slave mode, the slave cumulative clock low extend time ( $T_{\text{LOW:SEXT}}$ ) is detected

$$T_{\text{LOW:EXT}} = (\text{CLKTO } (\text{I2C\_CLKTOUT}[7:0])+1) \times 16 \times 1024 \text{ (14-bit)} \times T_{\text{PCLK}} \text{ (if TOCDIV4= 0).}$$

$$= (\text{CLKTO } (\text{I2C\_CLKTOUT}[7:0])+1) \times 16 \times 1024 \text{ (14-bit)} \times 4 \times T_{\text{PCLK}} \text{ (if TOCDIV4= 1)}$$



Figure 6.22-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  $T_{\text{IDLE}}$  greater than  $T_{\text{HIGH,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.22.5.3 PDMA Transfer Function

The I<sup>2</sup>C controller supports PDMA transfer function. When TXPDMAEN (I2C\_CTL1 [0]) is set to 1, the I<sup>2</sup>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<sup>2</sup>C controller will start the receive PDMA process. The I<sup>2</sup>C controller will issue the request to PDMA controller automatically when there is data written into the received BUFFER.

When I<sup>2</sup>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 (0x20, 0x30, 0x38, 0x48, 0x58, 0x00, 0xA0, 0xC0, 0x88 and 0x98).

Set the PDMASTR (I2C\_CTL1 [8]) only the I<sup>2</sup>C controller in master TX mode. If PDMASTR is cleared to 0, I<sup>2</sup>C will send STOP automatically after PDMA transfer done and buffer empty. If PDMASTR is set to 1, SI will be set to 1 and I<sup>2</sup>C bus will be stretched by hardware after PDMA transfer done and buffer empty.

#### 6.22.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 affected by stretched.

User should focus the limitation of setup and hold time configuration, the timing setting must follow I<sup>2</sup>C protocol. Once setup time configuration greater than design limitation, that means if setup time setting make SCL output less than three PCLKs, the I<sup>2</sup>C controller can't work normally due to SCL must sample three times. And once hold time configuration greater than I<sup>2</sup>C clock limitation, I<sup>2</sup>C will occur bus error. It is suggested that user calculate suitable timing with baud rate and protocol before setting timing. Table 6.22-2 shows the relationship between I<sup>2</sup>C baud rate and PCLK, the number of table represent one clock duty contain how many PCLKs. Setup and hold time configuration even can program some extreme values in the design, but user should follow I<sup>2</sup>C protocol standard.

| I <sup>2</sup> C Baud Rate<br>PCLK | 100k | 200k | 400k | 800k | 1200k |
|------------------------------------|------|------|------|------|-------|
| 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.22-2 Relationship between I<sup>2</sup>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_{limit} = (I2C\_CLKDIV[7:0]+1) \times 2 - 6$ .



Figure 6.22-23 Setup Time Wrong Adjustment

For hold time wrong adjustment example, use I<sup>2</sup>C Baud Rate = 1200k and PCLK = 72MHz, 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:  $HT_{limit} = (I2C\_CLKDIV[7:0]+1) \times 2 - 9$ .



Figure 6.22-24 Hold Time Wrong Adjustment

### 6.22.5.5 I<sup>2</sup>C Protocol Registers

To control I<sup>2</sup>C port through the following fifteen special function registers: I2C\_CTL0 (control register), I2C\_STATUS0 (status register), I2C\_DAT (data register), I2C\_ADDRn (address registers, n=0~3), I2C\_ADDRMSKn (address mask registers, n=0~3), I2C\_CLKDIV (clock rate register), I2C\_TOCTL (Time-out control register), I2C\_WKCTL(wake up control register) and I2C\_WKSTS(wake up status register).

#### Address Registers (I2C\_ADDR)

The I<sup>2</sup>C port is equipped with four slave address registers, I2C\_ADDRn (n=0~3). The contents of the register are irrelevant when I<sup>2</sup>C is in Master mode. In Slave mode, the bit field ADDR(I2C\_ADDRn[7:1]) must be loaded with the chip's own slave address. The I<sup>2</sup>C hardware will react if the contents of I2C\_ADDRn are matched with the received slave address.

The I<sup>2</sup>C ports support the “General Call” function. If the GC bit (I2C\_ADDRn [0]) is set the I<sup>2</sup>C port hardware will respond to General Call address (00H). Clear GC bit to disable general call function.

When the GC bit is set and the I<sup>2</sup>C is in Slave mode, it can receive the general call address by 00H after Master send general call address to I<sup>2</sup>C bus, then it will follow status of GC mode.

#### Slave Address Mask Registers (I2C\_ADDRMSK)

The I<sup>2</sup>C bus controller supports multiple address recognition with four address mask registers I2C\_ADDRMSKn (n=0~3). When the bit in the address mask register is set to 1, it means the received corresponding address bit is "Don't care". If the bit is set to 0, it means the received corresponding register bit should be exactly the same as address register.

### Data Register (I2C\_DAT)

This register contains a byte of serial data to be transmitted or a byte which just has been received. The CPU can be read from or written to the 8-bit (I2C\_DAT [7:0]) directly while it is not in the process of shifting a byte. When I<sup>2</sup>C is in a defined state and the serial interrupt flag (SI) is set, data in I2C\_DAT [7:0] remains stable. While data is being shifted out, data on the bus is simultaneously being shifted in; I2C\_DAT [7:0] always contains the last data byte presented on the bus.

The acknowledge bit is controlled by the I<sup>2</sup>C hardware and cannot be accessed by the CPU. Serial data is shifted into I2C\_DAT [7:0] on the rising edges of serial clock pulses on the SCL line. When a byte has been shifted into I2C\_DAT [7:0], the serial data is available in I2C\_DAT [7:0], and the acknowledge bit (ACK or NACK) is returned by the control logic during the ninth clock pulse. In order to monitor bus status while sending data, the bus data will be shifted to I2C\_DAT[7:0] when sending I2C\_DAT[7:0] to bus. In the case of sending data, serial data bits are shifted out from I2C\_DAT [7:0] on the falling edge of SCL clocks, and is shifted to I2C\_DAT [7:0] on the rising edge of SCL clocks. Figure 6.22-25 shows I<sup>2</sup>C Data Shifting Direction.



Figure 6.22-25 I<sup>2</sup>C Data Shifting Direction

### Control Register (I2C\_CTL0)

The CPU can be read from and written to I2C\_CTL0 [7:0] directly. When the I<sup>2</sup>C port is enabled by setting I2CEN (I2C\_CTL0 [6]) to high, the internal states will be controlled by I2C\_CTL0 and I<sup>2</sup>C logic hardware.

There are two bits affected by hardware: the SI bit is set when the I<sup>2</sup>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\_STATUS0, the I<sup>2</sup>C Interrupt Flag bit SI (I2C\_CTL0 [3]) will be set automatically. If the Enable Interrupt bit INTEN (I2C\_CTL0 [7]) is set at this time, the I<sup>2</sup>C interrupt will be generated. The bit field I2C\_STATUS0[7:0] stores the internal state code, the content keeps stable until SI is cleared by software.

### Status Register (I2C\_STATUS0)

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.22-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<sup>2</sup>C states. When each of these states is entered, a status interrupt is requested (SI = 1). A valid status code is present in I2C\_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 00H stands for a Bus Error, which occurs when a START or STOP condition is present at an incorrect position in the I<sup>2</sup>C format frame. A Bus Error may occur during the serial transfer of an address byte, a data byte or an acknowledge bit. To recover I<sup>2</sup>C from bus error, STO should be set and SI should be cleared to enter Not Addressed Slave mode. Then STO is cleared to release bus and to wait for a new communication. The I<sup>2</sup>C bus cannot recognize stop condition during this action when a bus error occurs.

| Master Mode         |                                                                                                                                                 | Slave Mode          |                                     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------|
| Status              | Description                                                                                                                                     | Status              | Description                         |
| 0x08 <sup>[1]</sup> | Start                                                                                                                                           | 0xA0                | Slave Transmit Repeat Start or Stop |
| 0x10 <sup>[1]</sup> | Master Repeat Start                                                                                                                             | 0xA8 <sup>[1]</sup> | Slave Transmit Address ACK          |
| 0x18 <sup>[1]</sup> | Master Transmit Address ACK                                                                                                                     | 0xB8 <sup>[1]</sup> | Slave Transmit Data ACK             |
| 0x20                | Master Transmit Address NACK                                                                                                                    | 0xC0                | Slave Transmit Data NACK            |
| 0x28 <sup>[1]</sup> | Master Transmit Data ACK                                                                                                                        | 0xC8 <sup>[1]</sup> | Slave Transmit Last Data ACK        |
| 0x30                | Master Transmit Data NACK                                                                                                                       | 0x60 <sup>[1]</sup> | Slave Receive Address ACK           |
| 0x38                | Master Arbitration Lost                                                                                                                         | 0x68 <sup>[1]</sup> | Slave Receive Arbitration Lost      |
| 0x40 <sup>[1]</sup> | Master Receive Address ACK                                                                                                                      | 0x80 <sup>[1]</sup> | Slave Receive Data ACK              |
| 0x48                | Master Receive Address NACK                                                                                                                     | 0x88                | Slave Receive Data NACK             |
| 0x50 <sup>[1]</sup> | Master Receive Data ACK                                                                                                                         | 0x70 <sup>[1]</sup> | GC mode Address ACK                 |
| 0x58                | Master Receive Data NACK                                                                                                                        | 0x78 <sup>[1]</sup> | GC mode Arbitration Lost            |
| 0x00                | Bus error                                                                                                                                       | 0x90 <sup>[1]</sup> | GC mode Data ACK                    |
|                     |                                                                                                                                                 | 0x98                | GC mode Data NACK                   |
|                     |                                                                                                                                                 | 0xB0 <sup>[1]</sup> | Address Transmit Arbitration Lost   |
| 0xF0                | If the BMDEN =1 and the ACKMEN bit is enabled, the information of I2C_STATUS0 will be fixed as 0xF0 in slave receive condition.                 |                     |                                     |
| 0xF8                | Bus Released<br><br>Note: Status "0xF8" exists in both master/slave modes, and it won't raise interrupt.<br>Note [1]: No interrupt in PDMA mode |                     |                                     |

Table 6.22-3 I<sup>2</sup>C Status Code Description**Clock Baud Rate Bits (I2C\_CLKDIV)**

The data baud rate of I<sup>2</sup>C is determined by DIVIDER(I2C\_CLKDIV [7:0]) register when I<sup>2</sup>C is in Master mode, and it is not necessary in a Slave mode. In the Slave mode, I<sup>2</sup>C will automatically synchronize it with any clock frequency from master I<sup>2</sup>C device. In the slave mode, system clock frequency should be greater than I<sup>2</sup>C bus maximum clock 20 times.

The data baud rate of I<sup>2</sup>C setting is Data Baud Rate of I<sup>2</sup>C = (system clock) / (4x (I2C\_CLKDIV [7:0] +1)). If system clock = 16 MHz, the I2C\_CLKDIV [7:0] = 40 (28H), the data baud rate of I<sup>2</sup>C = 16 MHz / (4x (40 +1)) = 97.5 Kbits/sec.

**Time-out Control Register (I2C\_TOCTL)**

There is a 14-bit time-out counter which can be used to deal with the I<sup>2</sup>C bus hang-up. If the time-out counter is enabled, the counter starts up counting until it overflows (TOIF=1) and generates I<sup>2</sup>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 I<sup>2</sup>C bus hangs up, it causes the I2C\_STATUS0 and flag SI are not updated for a period, the 14-bit time-out counter may overflow and acknowledge CPU the I<sup>2</sup>C interrupt. Refer to Figure 6.22-26 for the 14-bit time-out counter. User may write 1 to clear TOIF to 0.

Figure 6.22-26 I<sup>2</sup>C Time-out Count Block Diagram**Wake-up Control Register (I<sup>2</sup>C\_WKCTL)**

When chip enters Power-down mode and set WKEN (I<sup>2</sup>C\_WKCTL [0]) to 1, other I<sup>2</sup>C master can wake up the chip by addressing the I<sup>2</sup>C device, user must configure the related setting before entering sleep mode. The ACK bit cycle of address match frame is done in power-down. The controller will stretch the SCL to low when the address is matched the device's address and the ACK cycle done, then the I<sup>2</sup>C controller will go ahead. If NHDBUSEN (I<sup>2</sup>C\_WKCTL [7]) is set, the controller will don't stretch the SCL to low. Note that when the controller don't stretch the SCL to low, transmit or receive data will perform immediately. If data transmitted or received when SI event is not clear, user must reset the I<sup>2</sup>C controller and execute the original operation again.

**Wake-up Status Register (I<sup>2</sup>C\_WKSTS)**

When system is woken up by other I<sup>2</sup>C master device, WKIF is set to indicate this event. User needs write "1" to clear this bit.

When the chip is woken-up by address match with one of the device address register (I<sup>2</sup>C\_ADDRn), the user shall check the WKAKDONE (I<sup>2</sup>C\_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 (I<sup>2</sup>C\_WKSTS [2]) bit records the Read/Write command before the I<sup>2</sup>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 wake-up by the address match frame. Note that the WRSTSWK (I<sup>2</sup>C\_WKSTS [2]) bit is cleared when writing one to the WKAKDONE (I<sup>2</sup>C\_WKSTS [1]) bit.

When system is woken up by other I<sup>2</sup>C master device, WKIF is set to indicate this event. User needs to write "1" to clear this bit.



Figure 6.22-27 I<sup>2</sup>C Wake-Up Related Signals Waveform**I<sup>2</sup>C Control Register 1 (I2C\_CTL1)**

If enable 10-bit addressing mode ADDR10EN (I2C\_CTL1 [9]) is set, the I<sup>2</sup>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.

**I<sup>2</sup>C Status Register 1 (I2C\_STATUS1)**

The I<sup>2</sup>C controller supports four slave address flag registers, ADMAT0, ADMAT1, ADMAT2 and ADMAT3 (I2C\_STATUS1[3:0]). Every control register represent which address is used and set 1 to inform software.

**I<sup>2</sup>C 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.

**I<sup>2</sup>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 time-out control flow.

**I<sup>2</sup>C 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.

**I<sup>2</sup>C Byte Number Register (I2C\_PKTSIZE)**

When the PECEN bit (I2C\_BUSCTL[1]) is set. The I<sup>2</sup>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.

**I<sup>2</sup>C PEC VALUR Register (I2C\_PKTCRC)**

The register indicates the calculated PECCRC (I2C\_PKTCRC[7:0]) value of data on the I<sup>2</sup>C bus. The

detail of information is defined the Bus Management (SMBus/PMBus Compatiable).

#### I<sup>2</sup>C Bus Management Timer and I<sup>2</sup>C Clock Low Timer Register (I2C\_BUSTOUT/ I2C\_CLKTOUT)

Both of the definitions of these registers are described in the Bus Management (SMBus/PMBus Compatiable)

##### 6.22.5.6 Example for Random Read on EEPROM

The following steps are used to configure the I<sup>2</sup>C0 related registers when using I<sup>2</sup>C to read data from EEPROM.

1. Set I2C0 the multi-function pin as SCL and SDA pins The muti-function configuration reference Basic Configuration.
2. Enable I2C0 APB clock. The clock configuration reference Basic Configuration.
3. Set I2C0RST=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\_CTL0” register.
5. Give I2C0 clock a divided register value for I2C clock rate in the “I2C\_CLKDIV”.
6. Enable system I2C0 IRQ in system “NVIC” control register.
7. Set INTEN=1 to enable I2C0 Interrupt in the “I2C\_CTL0” register.
8. Set I2C0 address registers “I2C\_ADDR0 ~ I2C\_ADDR3”.

Random read operation is one of the methods of access EEPROM. The method allows the master to access any address of EEPROM space. Figure 6.22-28 shows the EEPROM random read operation.



Figure 6.22-28 EEPROM Random Read

Figure 6.22-29 shows how to use the I<sup>2</sup>C controller to implement the protocol of EEPROM random read.



Figure 6.22-29 Protocol of EEPROM Random Read

The I<sup>2</sup>C controller, which is a master, sends START to bus. Then, it sends a SLA+W (Slave address + Write bit) to EEPROM followed by two bytes data address to set the EEPROM address to read. Finally, a Repeat START followed by SLA+R is sent to read the data from EEPROM.

### 6.22.6 Register Map

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

| Register                                   | Offset       | R/W | Description                                                 | Reset Value |
|--------------------------------------------|--------------|-----|-------------------------------------------------------------|-------------|
| <b>I<sup>2</sup>C Base Address:</b>        |              |     |                                                             |             |
| <b>I2Cn_BA = 0x4008_0000 + (0x1000 *n)</b> |              |     |                                                             |             |
| <b>n= 0,1,2</b>                            |              |     |                                                             |             |
| <b>I2C_CTL0</b>                            | I2Cn_BA+0x00 | R/W | I <sup>2</sup> C Control Register 0                         | 0x0000_0000 |
| <b>I2C_ADDR0</b>                           | I2Cn_BA+0x04 | R/W | I <sup>2</sup> C Slave Address Register0                    | 0x0000_0000 |
| <b>I2C_DAT</b>                             | I2Cn_BA+0x08 | R/W | I <sup>2</sup> C Data Register                              | 0x0000_0000 |
| <b>I2C_STATUS0</b>                         | I2Cn_BA+0x0C | R   | I <sup>2</sup> C Status Register 0                          | 0x0000_00F8 |
| <b>I2C_CLKDIV</b>                          | I2Cn_BA+0x10 | R/W | I <sup>2</sup> C Clock Divided Register                     | 0x0000_0000 |
| <b>I2C_TOCTL</b>                           | I2Cn_BA+0x14 | R/W | I <sup>2</sup> C Time-out Control Register                  | 0x0000_0000 |
| <b>I2C_ADDR1</b>                           | I2Cn_BA+0x18 | R/W | I <sup>2</sup> C Slave Address Register1                    | 0x0000_0000 |
| <b>I2C_ADDR2</b>                           | I2Cn_BA+0x1C | R/W | I <sup>2</sup> C Slave Address Register2                    | 0x0000_0000 |
| <b>I2C_ADDR3</b>                           | I2Cn_BA+0x20 | R/W | I <sup>2</sup> C Slave Address Register3                    | 0x0000_0000 |
| <b>I2C_ADDRMSK0</b>                        | I2Cn_BA+0x24 | R/W | I <sup>2</sup> C Slave Address Mask Register0               | 0x0000_0000 |
| <b>I2C_ADDRMSK1</b>                        | I2Cn_BA+0x28 | R/W | I <sup>2</sup> C Slave Address Mask Register1               | 0x0000_0000 |
| <b>I2C_ADDRMSK2</b>                        | I2Cn_BA+0x2C | R/W | I <sup>2</sup> C Slave Address Mask Register2               | 0x0000_0000 |
| <b>I2C_ADDRMSK3</b>                        | I2Cn_BA+0x30 | R/W | I <sup>2</sup> C Slave Address Mask Register3               | 0x0000_0000 |
| <b>I2C_WKCTL</b>                           | I2Cn_BA+0x3C | R/W | I <sup>2</sup> C Wake-up Control Register                   | 0x0000_0000 |
| <b>I2C_WKSTS</b>                           | I2Cn_BA+0x40 | R/W | I <sup>2</sup> C Wake-up Status Register                    | 0x0000_0000 |
| <b>I2C_CTL1</b>                            | I2Cn_BA+0x44 | R/W | I <sup>2</sup> C Control Register 1                         | 0x0000_0000 |
| <b>I2C_STATUS1</b>                         | I2Cn_BA+0x48 | R/W | I <sup>2</sup> C Status Register 1                          | 0x0000_0000 |
| <b>I2C_TMCTL</b>                           | I2Cn_BA+0x4C | R/W | I <sup>2</sup> C Timing Configure Control Register          | 0x0000_0000 |
| <b>I2C_BUSCTL</b>                          | I2Cn_BA+0x50 | R/W | I <sup>2</sup> C Bus Management Control Register            | 0x0000_0000 |
| <b>I2C_BUSTCTL</b>                         | I2Cn_BA+0x54 | R/W | I <sup>2</sup> C Bus Management Timer Control Register      | 0x0000_0000 |
| <b>I2C_BUSSTS</b>                          | I2Cn_BA+0x58 | R/W | I <sup>2</sup> C Bus Management Status Register             | 0x0000_0000 |
| <b>I2C_PKTSIZE</b>                         | I2Cn_BA+0x5C | R/W | I <sup>2</sup> C Packet Error Checking Byte Number Register | 0x0000_0000 |
| <b>I2C_PKTCRC</b>                          | I2Cn_BA+0x60 | R   | I <sup>2</sup> C Packet Error Checking Byte Value Register  | 0x0000_0000 |
| <b>I2C_BUSTOUT</b>                         | I2Cn_BA+0x64 | R/W | I <sup>2</sup> C Bus Management Timer Register              | 0x0000_0005 |
| <b>I2C_CLKTOUT</b>                         | I2Cn_BA+0x68 | R/W | I <sup>2</sup> C Bus Management Clock Low Timer Register    | 0x0000_0005 |

### 6.22.7 Register Description

#### I<sup>2</sup>C Control Register (I2C\_CTL0)

| Register | Offset       | R/W | Description                         |  |  |  | Reset Value |
|----------|--------------|-----|-------------------------------------|--|--|--|-------------|
| I2C_CTL0 | I2Cn_BA+0x00 | R/W | I <sup>2</sup> C Control Register 0 |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [7]    | INTEN       | <b>Enable Interrupt</b><br>0 = I <sup>2</sup> C interrupt Disabled.<br>1 = I <sup>2</sup> C interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                   |
| [6]    | I2CEN       | <b>I<sup>2</sup>C Controller Enable Bit</b><br>Set to enable I <sup>2</sup> C serial function controller. When I2CEN=1 the I <sup>2</sup> C serial function enable. The multi-function pin function must set to SDA, and SCL of I <sup>2</sup> C function first.<br>0 = I <sup>2</sup> C controller Disabled.<br>1 = I <sup>2</sup> C controller Enabled.                                                                                                                                        |
| [5]    | STA         | <b>I<sup>2</sup>C START Control</b><br>Setting STA to logic 1 to enter Master mode, the I <sup>2</sup> C hardware sends a START or repeat START condition to bus when the bus is free.                                                                                                                                                                                                                                                                                                           |
| [4]    | STO         | <b>I<sup>2</sup>C STOP Control</b><br>In Master mode, setting STO to transmit a STOP condition to bus then I <sup>2</sup> C controller will check the bus condition if a STOP condition is detected. This bit will be cleared by hardware automatically.                                                                                                                                                                                                                                         |
| [3]    | SI          | <b>I<sup>2</sup>C Interrupt Flag</b><br>When a new I <sup>2</sup> C state is present in the I2C_STATUS0 register, the SI flag is set by hardware. If bit INTEN (I2C_CTL0 [7]) is set, the I <sup>2</sup> C interrupt is requested. SI must be cleared by software. Clear SI by writing 1 to this bit.<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          | <b>Assert Acknowledge Control</b><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 AA=0 prior to address or data received, a Not acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on                 |

|       |          |               |
|-------|----------|---------------|
|       |          | the SCL line. |
| [1:0] | Reserved | Reserved.     |

**I<sup>2</sup>C Data Register (I2C\_DAT)**

| Register | Offset       | R/W | Description                    |  |  |  | Reset Value |
|----------|--------------|-----|--------------------------------|--|--|--|-------------|
| I2C_DAT  | I2Cn_BA+0x08 | R/W | I <sup>2</sup> C Data Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                               |
| [7:0]  | DAT         | I <sup>2</sup> C Data<br>Bit [7:0] is located with the 8-bit transferred/received data of I <sup>2</sup> C serial port. |

**I<sup>2</sup>C Status Register (I2C\_STATUS0)**

| Register    | Offset       | R/W | Description                        | Reset Value |
|-------------|--------------|-----|------------------------------------|-------------|
| I2C_STATUS0 | I2Cn_BA+0x0C | R   | I <sup>2</sup> C Status Register 0 | 0x0000_00F8 |

|          |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| Reserved |    |    |    |    |    |    |    |
| 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| 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]  | STATUS      | <p><b>I<sup>2</sup>C Status</b></p> <p>The three least significant bits are always 0. The five most significant bits contain the status code. There are 28 possible status codes. When the content of I2C_STATUS0 is F8H, no serial interrupt is requested. Others I2C_STATUS0 values correspond to defined I<sup>2</sup>C states. When each of these states is entered, a status interrupt is requested (SI = 1). A valid status code is present in I2C_STATUS0 one cycle after SI is set by hardware and is still present one cycle after SI has been reset by software. In addition, states 00H stands for a Bus Error. A Bus Error occurs when a START or STOP condition is present at an illegal position in the formation frame. Example of illegal position are during the serial transfer of an address byte, a data byte or an acknowledge bit.</p> |

**I<sup>2</sup>C Clock Divided Register (I2C\_CLKDIV)**

| Register   | Offset       | R/W | Description                             | Reset Value |
|------------|--------------|-----|-----------------------------------------|-------------|
| I2C_CLKDIV | I2Cn_BA+0x10 | R/W | I <sup>2</sup> C Clock Divided Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                    |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                          |
| [9:0]   | DIVIDER     | <b>I<sup>2</sup>C Clock Divided</b><br>Indicates the I <sup>2</sup> C clock rate: Data Baud Rate of I <sup>2</sup> C = (system clock) / (4x (I2C_CLKDIV+1)).<br><b>Note:</b> The minimum value of I2C_CLKDIV is 4. |

**I<sup>2</sup>C Time-out Control Register (I2C\_TOCTL)**

| Register  | Offset       | R/W | Description                                | Reset Value |
|-----------|--------------|-----|--------------------------------------------|-------------|
| I2C_TOCTL | I2Cn_BA+0x14 | R/W | I <sup>2</sup> C Time-out Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                    |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                          |
| [2]    | TOCEN       | <b>Time-out Counter Enable Bit</b><br>When enabled, the 14-bit time-out counter will start counting when SI is cleared. Setting flag SI to '1' will reset counter and re-start up counting after SI is cleared.<br>0 = Time-out counter Disabled.<br>1 = Time-out counter Enabled. |
| [1]    | TOCDIV4     | <b>Time-out Counter Input Clock Divided by 4</b><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        | <b>Time-out Flag</b><br>This bit is set by hardware when I <sup>2</sup> C time-out happened and it can interrupt CPU if I <sup>2</sup> C interrupt enable bit (INTEN) is set to 1.<br><b>Note:</b> Software can write 1 to clear this bit.                                         |

**I<sup>2</sup>C Slave Address Register (ADDRx)**

| Register               | Offset       | R/W | Description                              | Reset Value |
|------------------------|--------------|-----|------------------------------------------|-------------|
| I <sup>2</sup> C_ADDR0 | I2Cn_BA+0x04 | R/W | I <sup>2</sup> C Slave Address Register0 | 0x0000_0000 |
| I <sup>2</sup> C_ADDR1 | I2Cn_BA+0x18 | R/W | I <sup>2</sup> C Slave Address Register1 | 0x0000_0000 |
| I <sup>2</sup> C_ADDR2 | I2Cn_BA+0x1C | R/W | I <sup>2</sup> C Slave Address Register2 | 0x0000_0000 |
| I <sup>2</sup> C_ADDR3 | I2Cn_BA+0x20 | R/W | I <sup>2</sup> C Slave Address Register3 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                    |
| [10:1]  | ADDR        | <p><b>I<sup>2</sup>C Address</b><br/>           The content of this register is irrelevant when I<sup>2</sup>C is in Master mode. In the slave mode, the seven most significant bits must be loaded with the chip's own address. The I<sup>2</sup>C hardware will react if either of the address is matched.</p> <p><b>Note:</b> When software set 10'h000, the address can not be used.</p> |
| [0]     | GC          | <p><b>General Call Function</b><br/>           0 = General Call Function Disabled.<br/>           1 = General Call Function Enabled.</p>                                                                                                                                                                                                                                                     |

**I<sup>2</sup>C Slave Address Mask Register (ADDRMSKx)**

| Register                  | Offset       | R/W | Description                                   |  |  |  | Reset Value |
|---------------------------|--------------|-----|-----------------------------------------------|--|--|--|-------------|
| I <sup>2</sup> C_ADDRMSK0 | I2Cn_BA+0x24 | R/W | I <sup>2</sup> C Slave Address Mask Register0 |  |  |  | 0x0000_0000 |
| I <sup>2</sup> C_ADDRMSK1 | I2Cn_BA+0x28 | R/W | I <sup>2</sup> C Slave Address Mask Register1 |  |  |  | 0x0000_0000 |
| I <sup>2</sup> C_ADDRMSK2 | I2Cn_BA+0x2C | R/W | I <sup>2</sup> C Slave Address Mask Register2 |  |  |  | 0x0000_0000 |
| I <sup>2</sup> C_ADDRMSK3 | I2Cn_BA+0x30 | R/W | I <sup>2</sup> C Slave Address Mask Register3 |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [10:1]  | ADDRMSK     | <p><b>I<sup>2</sup>C Address Mask</b></p> <p>0 = Mask Disabled (the received corresponding register bit should be exact the same as address register.).</p> <p>1 = Mask Enabled (the received corresponding address bit is don't care.).</p> <p>I<sup>2</sup>C bus controllers support multiple address recognition with four address mask register. When the bit in the address mask register is set to one, it means the received corresponding address bit is don't-care. If the bit is set to zero, that means the received corresponding register bit should be exact the same as address register.</p> <p><b>Note:</b> The wake-up function can not use address mask.</p> |
| [0]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**I<sup>2</sup>C Wake-up Control Register (I<sup>2</sup>C\_WKCTL)**

| Register               | Offset       | R/W | Description                               | Reset Value |
|------------------------|--------------|-----|-------------------------------------------|-------------|
| I <sup>2</sup> C_WKCTL | I2Cn_BA+0x3C | R/W | I <sup>2</sup> C Wake-up Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [7]    | NHDBUSEN    | <b>I<sup>2</sup>C No Hold BUS Enable Bit</b><br>0 = I <sup>2</sup> C hold bus after wake-up.<br>1= I <sup>2</sup> C don't hold bus after wake-up.<br><b>Note:</b> The I <sup>2</sup> C controller could respond when WKIF event is not clear, it may cause error data transmitted or received. If data transmitted or received when WKIF event is not clear, user must reset I <sup>2</sup> C controller and execute the original operation again. |
| [6:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [0]    | WKEN        | <b>I<sup>2</sup>C Wake-up Enable Bit</b><br>0 = I <sup>2</sup> C wake-up function Disabled.<br>1= I <sup>2</sup> C wake-up function Enabled.                                                                                                                                                                                                                                                                                                       |

**I<sup>2</sup>C Wake-up Status Register (I2C\_WKSTS)**

| Register  | Offset       | R/W | Description                              |  |  |  |  | Reset Value |
|-----------|--------------|-----|------------------------------------------|--|--|--|--|-------------|
| I2C_WKSTS | I2Cn_BA+0x40 | R/W | I <sup>2</sup> C Wake-up Status Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                             |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                   |
| [2]    | <b>WRSTSWK</b>  | <b>Read/Write Status Bit in Address Wakeup Frame</b><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><b>Note:</b> This bit will be cleared when software can write 1 to WKAKDONE bit. |
| [1]    | <b>WKAKDONE</b> | <b>Wakeup Address Frame Acknowledge Bit Done</b><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><b>Note:</b> This bit can't release WKIF. Software can write 1 to clear this bit.    |
| [0]    | <b>WKIF</b>     | <b>I<sup>2</sup>C Wake-up Flag</b><br>When chip is woken up from Power-down mode by I <sup>2</sup> C, this bit is set to 1. Software can write 1 to clear this bit.                                                                                                         |

**I<sup>2</sup>C Control Register 1 (I2C\_CTL1)**

| Register | Offset       | R/W | Description                         |  |  |  |  | Reset Value |
|----------|--------------|-----|-------------------------------------|--|--|--|--|-------------|
| I2C_CTL1 | I2Cn_BA+0x44 | R/W | I <sup>2</sup> C Control Register 1 |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                       |
| [9]    | ADDR10EN    | <b>Address 10-bit Function Enable Bit</b><br>0 = Address match 10-bit function Disabled.<br>1 = Address match 10-bit function Enabled.                                                                                                          |
| [8]    | PDMASTR     | <b>PDMA Stretch Bit</b><br>0 = I <sup>2</sup> C send STOP automatically after PDMA transfer done. (only master TX)<br>1 = I <sup>2</sup> C SCL bus is stretched by hardware after PDMA transfer done if the SI is not cleared. (only master TX) |
| [7:3]  | Reserved    | Reserved.                                                                                                                                                                                                                                       |
| [2]    | PDMARST     | <b>PDMA Reset</b><br>0 = No effect.<br>1 = Reset the I <sup>2</sup> C request to PDMA.                                                                                                                                                          |
| [1]    | RXPDMAEN    | <b>PDMA Receive Channel Available</b><br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.                                                                                                                              |
| [0]    | TXPDMAEN    | <b>PDMA Transmit Channel Available</b><br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled.                                                                                                                           |

**I<sup>2</sup>C Status Register 1 (I2C\_STATUS1)**

| Register    | Offset       | R/W | Description                        |  |  |  |  | Reset Value |
|-------------|--------------|-----|------------------------------------|--|--|--|--|-------------|
| I2C_STATUS1 | I2Cn_BA+0x48 | R/W | I <sup>2</sup> C Status Register 1 |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                      |
| [8]    | ONBUSY      | <p><b>On Bus Busy (Read Only)</b></p> <p>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.</p> <p>0 = The bus is IDLE (both SCLK and SDA High).</p> <p>1 = The bus is busy.</p> |
| [7:4]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                      |
| [3]    | ADMAT3      | <p><b>I<sup>2</sup>C Address 3 Match Status</b></p> <p>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.</p>                                                                                                             |
| [2]    | ADMAT2      | <p><b>I<sup>2</sup>C Address 2 Match Status</b></p> <p>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.</p>                                                                                                             |
| [1]    | ADMAT1      | <p><b>I<sup>2</sup>C Address 1 Match Status</b></p> <p>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.</p>                                                                                                             |
| [0]    | ADMAT0      | <p><b>I<sup>2</sup>C Address 0 Match Status</b></p> <p>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.</p>                                                                                                             |

**I<sup>2</sup>C Timing Configure Control Register (I2C\_TMCTL)**

| Register  | Offset       | R/W | Description                                        | Reset Value |
|-----------|--------------|-----|----------------------------------------------------|-------------|
| I2C_TMCTL | I2Cn_BA+0x4C | R/W | I <sup>2</sup> C Timing Configure Control Register | 0x0000_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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                        |
| [24:16] | <b>HTCTL</b>    | <p><b>Hold Time Configure Control</b><br/> This field is used to generate the delay timing between SCL falling edge and SDA rising edge in transmission mode.<br/> The delay hold time is numbers of peripheral clock = HTCTL x PCLK.</p>                                                                                        |
| [15:9]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                        |
| [8:0]   | <b>STCTL</b>    | <p><b>Setup Time Configure Control</b><br/> This field is used to generate a delay timing between SDA falling edge and SCL rising edge in transmission mode.<br/> The delay setup time is numbers of peripheral clock = STCTL x PCLK.<br/> <b>Note:</b> Setup time setting should not make SCL output less than three PCLKs.</p> |

**I<sup>2</sup>C Bus Manage Control Register (I2C\_BUSCTL)**

| Register   | Offset       | R/W | Description                                      |  |  |  | Reset Value |
|------------|--------------|-----|--------------------------------------------------|--|--|--|-------------|
| I2C_BUSCTL | I2Cn_BA+0x50 | R/W | I <sup>2</sup> C Bus Management 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 |         | 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     | <b>Packet Error Checking Byte Transfer Done Interrupt Enable Bit</b><br>0 = PEC transfer done interrupt Disabled.<br>1 = PEC transfer done interrupt Enabled.<br><b>Note:</b> This bit is used in PECEN =1.                                                                                                                                                                                                            |
| [12]    | BCDIEN      | <b>Packet Error Checking Byte Count Done Interrupt Enable Bit</b><br>0 = Byte count done interrupt Disabled.<br>1 = Byte count done interrupt Enabled.<br><b>Note:</b> This bit is used in PECEN =1.                                                                                                                                                                                                                   |
| [11]    | ACKM9SI     | <b>Acknowledge Manual Enable Extra SI Interrupt</b><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      | <b>PEC Clear at Repeat Start</b><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 PECCR bit is 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       | <b>Timer Check in Idle State</b><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><b>Note:</b> The BUSY (I2C_BUSSTS[0]) indicate the current bus state. |
| [8]     | PECTXEN     | <b>Packet Error Checking Byte Transmission/Reception</b><br>0 = No PEC transfer.<br>1 = PEC transmission is requested.                                                                                                                                                                                                                                                                                                 |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | <b>Note:</b> 1.This bit has no effect in slave mode when ACKMEN =0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [7] | <b>BUSEN</b>    | <p><b>BUS Enable Bit</b><br/>           0 = The system management function Disabled.<br/>           1 = The system management function Enabled.</p> <p><b>Note:</b> When the bit is enabled, the internal 14-bit counter is used to calculate the time out event of clock low condition.</p>                                                                                                                                                                                                                                                                                                                                            |
| [6] | <b>SCTLOEN</b>  | <p><b>Suspend or Control Pin Output Enable Bit</b><br/>           0 = The SUSCON pin in input.<br/>           1 = The output enable is active on the SUSCON pin.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [5] | <b>SCTLOSTS</b> | <p><b>Suspend/Control Data Output Status</b><br/>           0 = The output of SUSCON pin is low.<br/>           1 = The output of SUSCON pin is high.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [4] | <b>ALERTEN</b>  | <p><b>Bus Management Alert Enable Bit</b><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: 0001100x 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.</p>                                                                                                      |
| [3] | <b>BMHEN</b>    | <p><b>Bus Management Host Enable Bit</b><br/>           0 = Host function Disabled.<br/>           1 = Host function Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [2] | <b>BMDEN</b>    | <p><b>Bus Management Device Default Address Enable Bit</b><br/>           0 = Device default address Disable. When the address 0'b1100001x coming and the both of BMDEN and ACKMEN are enabled, the device responses NACKed<br/>           1 = Device default address Enabled. When the address 0'b1100001x coming and the both of BMDEN and ACKMEN are enabled, the device responses ACKed.</p>                                                                                                                                                                                                                                        |
| [1] | <b>PECEN</b>    | <p><b>Packet Error Checking Calculation Enable Bit</b><br/>           0 = Packet Error Checking Calculation Disabled.<br/>           1 = Packet Error Checking Calculation Enabled.</p> <p><b>Note:</b> When I<sup>2</sup>C enter powerdown mode, the bit should be enabled after wake-up if needed PEC calculation.</p>                                                                                                                                                                                                                                                                                                                |
| [0] | <b>ACKMEN</b>   | <p><b>Acknowledge Control by Manual</b><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.</p> <p><b>Note:</b> If the BMDEN =1 and this bit is enabled, the information of I2C_STATUS0 will be fixed as 0xF0 in slave receive condition.</p> |

I<sup>2</sup>C Bus Management Timer Control Register (I2C\_BUSTCTL)

| Register    | Offset       | R/W | Description                                            |  |  |  | Reset Value |
|-------------|--------------|-----|--------------------------------------------------------|--|--|--|-------------|
| I2C_BUSTCTL | I2Cn_BA+0x54 | R/W | I <sup>2</sup> C Bus Management Timer 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 |    |    | TORSTEN | CLKTOIEN | BUSTOIEN | CLKTOEN | BUSTOEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                      |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |
| [4]    | TORSTEN     | <b>Time Out Reset Enable Bit</b><br>0 = I <sup>2</sup> C state machine reset Disabled.<br>1 = I <sup>2</sup> C state machine reset Enabled. (The clock and data bus will be released to high)                                                                                        |
| [3]    | CLKTOIEN    | <b>Extended Clock Time Out Interrupt Enable Bit</b><br>0 = Clock time out interrupt Disabled.<br>1 = Clock time out interrupt Enabled.                                                                                                                                               |
| [2]    | BUSTOIEN    | <b>Time-out Interrupt Enable Bit</b><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     | <b>Cumulative Clock Low Time Out Enable Bit</b><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     | <b>Bus Time Out Enable Bit</b><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 TTime-out (in BIDLE=0) or high more than TTime-out(in BIDLE =1).                                                    |

**I<sup>2</sup>C Bus Management Status Register (I2C\_BUSSTS)**

| Register   | Offset       | R/W | Description                                     |  |  |  | Reset Value |
|------------|--------------|-----|-------------------------------------------------|--|--|--|-------------|
| I2C_BUSSTS | I2Cn_BA+0x58 | R/W | I <sup>2</sup> C Bus Management 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    |
| PECDONE  | CLKTO | BUSTO | SCTLDIN | ALERT | PECERR | BCDONE | BUSY |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [7]    | PECDONE     | <p><b>PEC Byte Transmission/Receive Done</b><br/>           0 = PEC transmission/ receive is not finished when the PECEEN is set.<br/>           1 = PEC transmission/ receive is finished when the PECEEN is set.<br/> <b>Note:</b> Software can write 1 to clear this bit.</p>                                                                                                                                                                                                                                                                             |
| [6]    | CLKTO       | <p><b>Clock Low Cumulate Time-out Status</b><br/>           0 = Cumulative clock low is no any time-out.<br/>           1 = Cumulative clock low time-out occurred.<br/> <b>Note:</b> Software can write 1 to clear this bit.</p>                                                                                                                                                                                                                                                                                                                            |
| [5]    | BUSTO       | <p><b>Bus Time-out Status</b><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/> <b>Note:</b> Software can write 1 to clear this bit.</p>                                                                                                                                                              |
| [4]    | SCTLDIN     | <p><b>Bus Suspend or Control Signal Input Status</b><br/>           0 = The input status of SUSCON pin is 0.<br/>           1 = The input status of SUSCON pin is 1.</p>                                                                                                                                                                                                                                                                                                                                                                                     |
| [3]    | ALERT       | <p><b>SMBus Alert Status</b><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 SMALETR pin when the BMHEN = 1 (SMBus host configuration) and the ALERTEN = 1.<br/> <b>Note:</b> 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.</p> |

|     |               |                                                                                                                                                                                                                                                                     |
|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>PECERR</b> | <b>PEC Error in Reception</b><br>0 = PEC value equal the received PEC data packet.<br>1 = PEC value doesn't match the receive PEC data packet.<br><b>Note:</b> Software can write 1 to clear this bit.                                                              |
| [1] | <b>BCDONE</b> | <b>Byte Count Transmission/Receive Done</b><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><b>Note:</b> Software can write 1 to clear this bit.       |
| [0] | <b>BUSY</b>   | <b>Bus Busy</b><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 = Bus is IDLE (both SCLK and SDA High).<br>1 = Bus is busy. |

**I<sup>2</sup>C Byte Number Register (I2C\_PKTSIZE)**

| Register    | Offset       | R/W | Description                                                 | Reset Value |
|-------------|--------------|-----|-------------------------------------------------------------|-------------|
| I2C_PKTSIZE | I2Cn_BA+0x5C | R/W | I <sup>2</sup> C Packet Error Checking Byte Number 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  |
| PLDSIZE  |    |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                      |
| [8:0]  | PLDSIZE     | <p><b>Transfer Byte Number</b></p> <p>The transmission or receive byte number in one transaction when the PECEN is set. The maximum transaction or receive byte is 256 Bytes.</p> <p><b>Note:</b> The byte number counting includes address, command code, and data frame.</p> |

**I<sup>2</sup>C PEC Value Register (I2C\_PKTCRC)**

| Register   | Offset       | R/W | Description                                                | Reset Value |
|------------|--------------|-----|------------------------------------------------------------|-------------|
| I2C_PKTCRC | I2Cn_BA+0x60 | R   | I <sup>2</sup> C Packet Error Checking Byte Value 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  |
| PECCRC   |    |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                       |
| [7:0]  | PECCRC      | <b>Packet Error Checking Byte Value</b><br>This byte indicates the packet error checking content after transmission or receive byte count by using the C(x) = X8 + X2 + X + 1. It is read only. |

**I<sup>2</sup>C Bus Management Timer Register (I2C\_BUSTOUT)**

| Register    | Offset       | R/W | Description                                    |  |  |  |  | Reset Value |
|-------------|--------------|-----|------------------------------------------------|--|--|--|--|-------------|
| I2C_BUSTOUT | I2Cn_BA+0x64 | R/W | I <sup>2</sup> C Bus Management Timer Register |  |  |  |  | 0x0000_0005 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                           |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                 |
| [7:0]  | BUSTO       | <p><b>Bus Management Time-out Value</b><br/>           Indicates the bus time-out value in bus is IDLE or SCLK low.</p> <p><b>Note:</b> If the user wants to revise the value of BUSTOUT, the TORSTEN (I2C_BUSTCTL[4]) bit shall be set to 1 and clear to 0 first in the BUSEN(I2C_BUSCTL[7]) is set.</p> |

**I<sup>2</sup>C Clock Low Timer Register (I2C\_CLKTOUT)**

| Register    | Offset       | R/W | Description                                              |  |  |  |  | Reset Value |
|-------------|--------------|-----|----------------------------------------------------------|--|--|--|--|-------------|
| I2C_CLKTOUT | I2Cn_BA+0x68 | R/W | I <sup>2</sup> C Bus Management Clock Low Timer Register |  |  |  |  | 0x0000_0005 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                    |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                          |
| [7:0]  | CLKTO       | <p><b>Bus Clock Low Timer</b></p> <p>The field is used to configure the cumulative clock extension time-out.</p> <p><b>Note:</b> If the user wants to revise the value of CLKLTOU, the TORSTEN bit shall be set to 1 and clear to 0 first in the BUSEN is set.</p> |

## 6.23 USCI - Universal Serial Control Interface Controller (USCI)

### 6.23.1 Overview

The Universal Serial Control Interface (USCI) is a flexible interface module covering several serial communication protocols. The user can configure this controller as UART, SPI, or I<sup>2</sup>C functional protocol.

### 6.23.2 Features

The controller can be individually configured to match the application needs. The following protocols are supported:

- UART
- SPI
- I<sup>2</sup>C

### 6.23.3 Block Diagram



Figure 6.23-1 USCI Block Diagram

### 6.23.4 Functional Description

The structure of the Universal Serial Control Interface (USCI) controller is shown in Figure 6.23-1 USCI Block Diagram. The input signal is implemented in input processor. The data buffers and the data shift unit support the data transfers. Each protocol-specific function is handled by the protocol processor unit. The timing and time event control signals of the specific protocol are handled by the protocol-relative clock generator. All the protocol-specific events are processed in the interrupt generation unit. The wake-up function of the specific protocol is implemented in the wake-up control unit.

The USCI is equipped with three protocols including UART, SPI, and I<sup>2</sup>C. They can be selected by FUNMODE (USCI\_CTL [2:0]). Note that the FUNMODE must be set to 0 before changing protocol.

#### 6.23.4.1 I/O Processor

##### Input Signal

All input stages offer the similar feature set. They are used for all protocols.

Table 6.23-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 <sup>2</sup> C |
|------------------------|------------|------|------------|------------------|
| Serial Bus Clock Input | USCIx_CLK  | -    | SPI_CLK    | SCL              |
| Control Input          | USCIx_CTL0 | nCTS | SPI_SS     | -                |
|                        | USCIx_CTL1 | -    | -          | -                |
| Data Input             | USCIx_DAT0 | RX   | SPI_MOSI_0 | SDA              |
|                        | USCIx_DAT1 | -    | SPI_MISO_0 | -                |

Table 6.23-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.23-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.23-3 Input Conditioning for USCIx\_CLK

All configurations of control, clock and data input structures are in USCI\_CTLIN0, USCI\_CLKIN and USCI\_DATIN0 registers respectively. EDGEDET (USCI\_DATIN0[4:3]) is used to select the edge detection condition. Note that the EDGEDET for USCI\_DATIN0 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\_DATIN0[2] / USCI\_CTLIN0[2]) allows a polarity inversion of the selected input signal to adapt the input signal polarity to the internal polarity of the data shift unit and the protocol state machine.

If the SYNCSEL (USCI\_DATIN0[0] / USCI\_CTLIN0[0] / USCI\_CLKIN[0]) is set to 0, the paths of input signals do not contain any delay due to synchronization or filtering. If there is noise on the input signals, there is the possibility to synchronize the input signal (signal IN\_SYNC is synchronized to  $f_{PCLK}$ ). The synchronized input signal is taken into account by SYNCSEL = 1. The synchronization leads to a delay in the signal path of 2-3 times the period of  $f_{PCLK}$ .

### Output Signals

Table 6.23-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 <sup>2</sup> C |
|-------------------------|------------|------|------------|------------------|
| Serial Bus Clock Output | USCIx_CLK  | -    | SPI_CLK    | SCL              |
| Control Output          | USCIx_CTL0 | -    | SPI_SS     | -                |
|                         | USCIx_CTL1 | nRTS | -          | -                |
| Data Output             | USCIx_DAT0 | -    | SPI_MOSI_0 | SDA              |
|                         | USCIx_DAT1 | TX   | SPI_MISO_0 | -                |

Table 6.23-2 Output Signals for Different Protocols

The description of protocol-specific items are given in the related protocol chapters.

#### 6.23.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 USCI<sub>x</sub>\_DAT0 pin or USCI<sub>x</sub>\_DAT1 pin depends on what protocol is selected.



Figure 6.23-4 Block Diagram of Data Buffering

The operation of data handling includes:

- The peripheral device user interface (APB) is used to handle data, interrupts, status and control information.
- A transmitter includes transmit shift register (TX\_SFTR) and a transmit data buffer (TX\_BUF). The TXFULL / TXEMPTY (USCI\_BUFSTS[9:8]) and TXENDIF (USCI\_PROTSTS[2]) can indicate the status of transmitter.
- A receiver includes receive shift register (RX\_SFTR) and a double receive buffer structure (RX\_BUFO, 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.23-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.23-6 Transmit Data Path

### Transmit Data Validation

The status of TXEMPTY (USCI\_BUFSTS[8]) indicates the transmission data is valid or not in the transmit buffer (TX\_BUF) and the TXSTIF (USCI\_PROTSTS[1]) labels the start conditions for each data.

- If the USCI controller is a Master, the data transfer can only be started with valid data in the transmit buffer (TX\_BUF). In this case, the transmit shift register is loaded with the content of transmit buffer.
- Note:** Master defines the start of data transfer.
- If the USCI controller is a Slave, a data transfer requested by Master and it has to be started independently of the status in transmit buffer (TX\_BUF). If a data transfer is

requested and started by the Master, the transmit shift register is loaded from specific protocol control signal if it is valid for transmission.

**Note:** Slave can not define the start itself, but has to react.

- The timing of loading data from transmit buffer to data shift unit depends on protocol configurations.
- **UART:** A transmission of the data word in transmit buffer can be started if TXEMPTY = 0 in normal operation. In auto flow control, A transmission of the data word in transmit buffer can be started while TXEMPTY = 0 and USCIx\_CTL0 in active stage.
- **SPI:** In Master mode, data transmission will be started when TXEMPTY (USCI\_BUFSTS[8]) is 0. In Slave mode, the data transmission can be started only when slave selection signal is at active state and clock is presented on USCIx\_CLK pin.
- **I<sup>2</sup>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\_BUF0 and RX\_BUF1. The data transfer parameters like data word length, or the shift direction are controlled commonly for transmission and reception by the line control register USCI\_LINECTL. Register USCI\_BUFSTS monitors the data validation of USCI\_RXDAT.

### Receive Buffering

The receive shift register cannot be directly accessed by user, but its content is automatically loaded into the receive buffer if a complete data word has been received or the frame is finished. The received data words in Receive Buffer can be read out automatically from register USCI\_RXDAT.



Figure 6.23-7 Receive Data Path

#### 6.23.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.23.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.23.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 below.



**Note:** Refer the **Basic Clock Divider Counter** section to get the  $f_{SAMP\_CLK}$

Figure 6.23-8 Protocol-Relative Clock Generator

The protocol related counter contains basic clock divider counter and timing measurement counter. It is based on a divider stages, providing the frequencies needed for the different protocols. It contains:

- The basic clock divider counter provides the protocol relative clock signal and other protocol-related signals ( $f_{SAMP\_CLK}$  and  $f_{DS\_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_{REF\_CLK2}$ ,  $f_{REF\_CLK}$ ,  $f_{DIV\_CLK}$ ,  $f_{SCLK}$ , and  $f_{SAMP\_CLK}$ . The frequencies of this divider are controlled by PTCLKSEL (USCI\_BRGEN [1]), CLKDIV (USCI\_BRGEN [25:16]), SPCLKSEL (USCI\_BRGEN [3:2]).

The basic clock divider counter is used to generate the relative protocol timing signals.

$$f_{DIV\_CLK} = f_{REF\_CLK} \times \frac{1}{CLKDIV + 1} \text{ if PTCLKSEL} = 0$$

$$f_{DIV\_CLK} = f_{REF\_CLK} \times \frac{1}{(CLKDIV + 1) \times 2} \text{ if PTCLKSEL} = 1$$



Figure 6.23-9 Basic Clock Divider Counter

### Timing Measurement Counter

The timing measurement counter is used for time interval measurement and is enabled by TMCNTEN (USCI\_BRGEN [4]) = 1. When TMCNTSRC (USCI\_BRGEN [5]) is set to 1, the timer works on  $f_{DIV\_CLK}$ , otherwise, the timer works independently from  $f_{PROT\_CLK}$ . Therefore, any serial data reception or transmission can continue while the timer is performing timing measurements. The timer counts the length of protocol-related signals with  $f_{PROT\_CLK}$  or  $f_{DIV\_CLK}$ . It stops counting when it reaches the user-specified value.



Figure 6.23-10 Block of Timing Measurement Counter

The timing measurement counter is used to perform time-out function or auto-baud rate mechanism. Its functionality depends on the selected protocol as shown below.

- UART: The timing measurement counter is used in auto baud rate detection.
- SPI: The timing measurement counter is used for counting the slave time-out period.
- I<sup>2</sup>C: The timing measurement counter indicates time-out clock cycle.

### Sample Time Counter

A sample time counter associated to the protocol related counter defining protocol specific timings, such shift control signals or bit timings, based on the input frequency  $f_{SAMP\_CLK}$ . The sample time

counter allows generating time intervals for protocol-specific purposes. The period of a sample frequency  $f_{PDS\_CNT}$  is given by the selected input frequency  $f_{SAMP\_CLK}$  and the programmed pre-divider value (PDSCNT (USCI\_BRGEN [9:8])). The meaning of the sample time depends on the selected protocol. Please refer to the corresponding chapters for more protocol-specific information.



Figure 6.23-11 Sample Time Counter

#### 6.23.4.6 Data Transfer Events and Interrupts

The data transfer events are based on the transmission or reception of a data word. The related indication flags are located in register USCI\_PROTSTS. All events can be individually enabled for interrupt generation. If the FUNMODE (USCI\_CTL [2:0]) is set to 0, the USCI is disabled. When FUNMODE (USCI\_CTL [2:0]) is setting for a protocol port, the internal states will be controlled by logic hardware of the selected protocol.

- Transmit start interrupt event to indicate that a data word has been started:

A transmit start interrupt event occurs when the data is loaded into transmitted shift register. It is indicated by flag TXSTIF (USCI\_PROTSTS [1]) and, if enabled, leads to transmit start interrupt.

- Transmit end interrupt event to indicate that a data word transmission has been done:

A transmit end interrupt event occurs when the current transmit data in shift register had been finished. It is indicated by flag TXENDIF (USCI\_PROTSTS [2]) and, if enabled, leads to transmit end interrupt. This event also indicates when the shift control settings (word length, shift direction, etc.) are internally “frozen” for the current data word transmission. In UART and I<sup>2</sup>C mode, the transmit data valid is according to TXEMPTY (USCI\_BUFSTS [8]) and protocol relative internal signal with the transmit end interrupt event.

- Receiver start event to indicate that a data word reception has started:

When the receive clock edge that shifts in the first bit of a new data word is detected and reception is enabled, a receiver start event occurs. It is indicated by flag RXSTIF (USCI\_PROTSTS [3]) and, if enabled, leads to receiver start interrupt.

- Receive event to indicate that a data word has been received:

If a new received word becomes available in the receive buffer, a receive event occurs. It is indicated by flag RXENDIF (USCI\_PROTSTS [4]) and, if enabled, leads to receive interrupt.

- Data lost event to indicate a loss of the newest received data word:

If the data word available in register USCI\_RXDAT (oldest data word from RX\_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

enabled, leads to a protocol interrupt.

The general event and interrupt structure is shown in Figure 6.23-12.



Figure 6.23-12 Event and Interrupt Structure

Each general interrupt enable can set by RXENDIEN, RXSTIEN, TXENDIEN, and TXSTIEN of USCI\_INTEN [4:1]. The events are including receive end interrupt event, receive start interrupt event, transmit end interrupt event, and transmit start interrupt event. For protocol-specific interrupt, it is specified in each protocol interrupt enable register.

If a defined condition is met, an event is detected and an event indication flag becomes automatically set. The flag stays set until it is cleared by software. If enabled, an interrupt can be generated if an event is detected.

The registers, bits and bit fields indicate the data transfer events and control the general interrupts of a USCI are shown in Table 6.23-3.

| Event                          | Indication Flag               | Indication Cleared By                                                              | Interrupt Enabled By         |
|--------------------------------|-------------------------------|------------------------------------------------------------------------------------|------------------------------|
| Transmit start interrupt event | TXSTIF<br>(USCI_PROTSTS [1])  | It is cleared by software writes 1 to corresponding interrupt bit of USCI_PROTSTS. | TXSTIEN<br>(USCI_INTEN [1])  |
| Transmit end interrupt event   | TXENDIF<br>(USCI_PROTSTS [2]) |                                                                                    | TXENDIEN<br>(USCI_INTEN [2]) |
| Receive start interrupt event  | RXSTIF<br>(USCI_PROTSTS [3])  |                                                                                    | RXSTIEN<br>(USCI_INTEN [3])  |
| Receive end interrupt event    | RXENDIF<br>(USCI_PROTSTS [4]) |                                                                                    | RXENDIEN<br>(USCI_INTEN [4]) |

Table 6.23-3 Data Transfer Events and Interrupt Handling

#### 6.23.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 I <sup>2</sup> C mode | USCI_PROTSTS [13:8], USCI_PROTSTS [5]        |                                                                                    | USCI_PROTIEN [6:0]   |

Table 6.23-4 Protocol-specific Events and Interrupt Handling

#### 6.23.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.23.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.24 USCI – UART Mode

### 6.24.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.24.2 Features

- Supports one transmit buffer and two receive buffer for data payload
- Supports hardware auto flow control function
- Supports programmable baud-rate generator
- Support 9-bit Data Transfer (Support 9-bit RS-485)
- Baud rate detection possible by built-in capture event of baud rate generator
- Supports PDMA capability
- Supports Wake-up function (Data and nCTS Wakeup Only)

### 6.24.3 Block Diagram



Figure 6.24-1 USCI-UART Mode Block Diagram

#### 6.24.4 Basic Configuration

The basic configurations of USCI0\_UART are as follows:

- Clock Source Configuration
- Enable USCI0 clock (USCI0CKEN) on CLK\_APBCLK1[8] register.
- Reset USCI0 (USCI0RST) on SYS\_IPRST2[8] register.
- Enable USCI0\_UART function USCI0\_CTL[2:0] register, USCI1\_CTL[2:0]=3'b010.
- Pin Configuration

| Group | Pin Name   | GPIO  | MFP  |
|-------|------------|-------|------|
| USCI0 | USCI0_CLK  | PD.0  | MFP3 |
|       |            | PB.12 | MFP5 |
|       |            | PA.11 | MFP6 |
|       |            | PE.2  | MFP7 |
|       | USCI0_CTL0 | PD.4  | MFP3 |
|       |            | PC.14 | MFP5 |
|       |            | PC.13 | MFP6 |
|       |            | PE.6  | MFP7 |
|       | USCI0_CTL1 | PD.3  | MFP3 |
|       |            | PB.15 | MFP5 |
|       |            | PA.8  | MFP6 |
|       |            | PE.5  | MFP7 |
|       | USCI0_DAT0 | PD.1  | MFP3 |
|       |            | PB.13 | MFP5 |
|       |            | PA.10 | MFP6 |
|       |            | PE.3  | MFP7 |
|       | USCI0_DAT1 | PD.2  | MFP3 |
|       |            | PB.14 | MFP5 |
|       |            | PA.9  | MFP6 |
|       |            | PE.4  | MFP7 |

The basic configurations of USCI1\_UART are as follows:

- Clock Source Configuration
- Enable USCI1 clock (USCI1CKEN) on CLK\_APBCLK1[9] register.
- Reset USCI1 (USCI1RST) on SYS\_IPRST2[9] register.
- Enable USCI1\_UART function USCI1\_CTL[2:0] register, USCI1\_CTL[2:0]=3'b010.
- Pin Configuration

| Group | Pin Name  | GPIO | MFP  |
|-------|-----------|------|------|
| USCI1 | USCI1_CLK | PB.8 | MFP4 |

|            |  |             |      |
|------------|--|-------------|------|
|            |  | PD.7, PE.12 | MFP6 |
|            |  | PB.1        | MFP8 |
| USCI1_CTL0 |  | PB.10       | MFP4 |
|            |  | PD.3, PE.9  | MFP6 |
|            |  | PB.5        | MFP8 |
|            |  | PB.9        | MFP4 |
| USCI1_CTL1 |  | PD.4, PE.8  | MFP6 |
|            |  | PB.4        | MFP8 |
|            |  | PB.7        | MFP4 |
| USCI1_DAT0 |  | PD.5, PE.10 | MFP6 |
|            |  | PB.2        | MFP8 |
|            |  | PB.6        | MFP4 |
| USCI1_DAT1 |  | PD.6, PE.11 | MFP6 |
|            |  | PB.3        | MFP8 |

## 6.24.5 Functional Description

### 6.24.5.1 USCI Common Function Description

Please refer to section 6.23.4 for detailed information.

### 6.24.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.24-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.24-2 UART Signal Connection for Full-Duplex Communication

**Input Signal**

For UART protocol, the number of input signals is shown in Table 6.24-1. Each input signal is handled by an input processor for signal conditioning, such as signal inverse selection control, or a digital input filter. They can be classified according to their meaning for the protocols (see Table 6.24-1).

| Selected Protocol |            | UART |
|-------------------|------------|------|
| Control Input     | USCIx_CTL0 | nCTS |
|                   | USCIx_CTL1 | X    |
| Data Input        | USCIx_DAT0 | RX   |
|                   | USCIx_DAT1 | X    |

Table 6.24-1 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.24-2 Output Signals for Different Protocol

**6.24.5.3 Frame Format**

A standard UART frame is shown in Figure 6.24-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.24-3 UART Standard Frame Format

The protocol specific bits (SOF, P, STOP) are automatically handled by the UART protocol state machine and do not appear in the data flow via the receive and transmit buffers.

**Start Bit**

The receiver input signal USCIx\_DAT0 is checked for a falling edge. An SOF bit is detected when a

falling edge occurs while the receiver is idle or after the sampling point of the last stop bit. To increase noise immunity, the SOF bit timing starts with the first falling edge that is detected. If the sampled bit value of the SOF is 1, the previous falling edge is considered to be due to noise and the receiver is considered to be idle again.

### **Data Field**

The length of the data field (number of data bits) can be programmed by the bit field DWIDTH (USCI\_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 (USCI\_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 (USCI\_PROTCTL[1]) and EVENPARITY (USCI\_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 (USCI\_PROTSTS). The register contains bits to monitor a protocol-related status and protocol-related error indication (FRMERR, PARITYERR).

### **Stop Bit**

Each UART frame is completed by 1 or 2 of stop bits with the signal level 1 (same level as the idle level). The number of stop bits is programmable by bit STOPB (USCI\_PROTCTL[0]). A new start bit can be transferred directly after the last stop bit.

### **Transfer Status Indication**

RXBUSY (USCI\_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.24.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 FUNMODE (USCI\_CTL[2:0]) to 010B and the UART protocol can be enabled by setting PROTEN (USCI\_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 USCI\_DATIN0. It is suggested to set EDGEDET (USCI\_DATIN0[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 USCI\_LINECTL.

The USCIx\_CTL0 pin is used for UART clear to send signal (nCTS) in UART protocol. The property of input control signal can be configured in USCI\_CTLIN0.

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 USCI\_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 USCI\_LINECTL and the USCI\_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 (USCI\_LINECTL[0]) to 1.

##### 6.24.5.5 Bit Timing

In UART mode, each frame bit is divided into data sample time in order to provide granularity in the sub-bit range to adjust the sample point to the application requirements. The number of data sample time per bit is defined by bit fields DSCNT (USCI\_BRGEN[14:10]) and the length of a data sample time is given by PDSCNT (USCI\_BRGEN[9:8]).

In the example given in Figure 6.24-4, one bit time is composed of 16 data sample time DSCNT(USCI\_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.24-4 UART Bit Timing (data sample time)

##### 6.24.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 (USCI\_BRGEN [0])

to define the input frequency fREF\_CLK

###### SPCLKSEL (USCI\_BRGEN[3:2])

to define the multiple source of the sample clock fSAM\_CLK

###### PDSCNT (USCI\_BRGEN [9:8])

to define the length of a data sample time (division of fREF\_CLK by 1, 2, 3, or 4)

###### DSCNT (USCI\_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<sub>PCLK</sub>), PTCLKSEL = 0 (f<sub>PROT\_CLK</sub> = f<sub>REF\_CLK</sub>) and SPCLKSEL = 2'b00 (f<sub>SAMP\_CLK</sub> = f<sub>DIV\_CLK</sub>). Under these conditions, the baud rate is given by:

$$f_{\text{UART}} = f_{\text{REF\_CLK}} \times \frac{1}{\text{CLKDIV} + 1} \times \frac{1}{\text{PDSCNT} + 1} \times \frac{1}{\text{DSCNT} + 1}$$

In order to generate slower frequencies, additional divide-by-2 stages can be selected by PTCLKSEL = 1 ( $f_{PROT\_CLK} = f_{REF\_CLK2}$ ), leading to:

$$f_{UART} = \frac{f_{REF\_CLK}}{2} \times \frac{1}{CLKDIV + 1} \times \frac{1}{PDSCNT + 1} \times \frac{1}{DSCNT + 1}$$

If SPCLKSEL = 2'b10 ( $f_{SAMP\_CLK} = f_{SCLK}$ ), and RCLKSEL = 0 ( $f_{REF\_CLK} = f_{PCLK}$ ), PTCLKSEL = 0 ( $f_{PROT\_CLK} = f_{REF\_CLK}$ ). The baud rate is given by:

$$f_{UART} = f_{REF\_CLK} \times \frac{1}{CLKDIV + 1} \times \frac{1}{2} \times \frac{1}{PDSCNT + 1} \times \frac{1}{DSCNT + 1}$$

There is error tolerance for the UART baud rate after setting the baud rate parameter. Table 6.26-1 lists the relative error percentage examples for user to calculate his relative baud rate setting.

| HCLK Source | PCLK Source | Expect Baud Rate | CLKDIV (USCI_BRGEN[25:16]) | DSCNT (USCI_BRGEN[14:10]) | PDSCNT | Active Baud Rate | Error Percentage |
|-------------|-------------|------------------|----------------------------|---------------------------|--------|------------------|------------------|
| 12MHz       | HCLK        | 115200           | 0xC                        | 0x7                       | 0x0    | 115384           | 0.16%            |
| 12MHz       | HCLK        | 9600             | 0x7C                       | 0x9                       | 0x0    | 9600             | 0%               |
| 12MHz       | HCLK        | 2400             | 0x1F3                      | 0x9                       | 0x0    | 2400             | 0%               |
|             |             |                  |                            |                           |        |                  |                  |
|             |             |                  |                            |                           |        |                  |                  |

Table 6.24-1 Baud Rate Relationship

**Note:** {SPCLKSEL, PTCLKSEL, RCLKSEL = 2'b0,1'b0,1'b0}

#### 6.24.5.7 Auto Baud Rate Detection

The UART controller supports auto baud rate detection function. It is used to identify the input baud rate from the receiver signal (USCIx\_DAT0) and then revised the baud rate clock divider CLKDIV (USCI\_BRGEN[25:16]) after the baud rate function done to meet the detected baud rate information. According the section of Timing Measurement Counter, the timing measurement counter is used for time interval measurement of the input signal (USCIx\_DAT0) and the actual timer value is captured into bit field BRDETITV (USCI\_PROTCTL [24:16]) in each falling edge of the detected signal.

When the ABREN (PROTOCOL[6]) bit is enabled, the 0x55 data patterns is necessary for auto baud rate detection. The falling edge of input signal starts the baud rate counter and it loads the timing measurement counter value into the BRDETITV (USCI\_PROTCTL [24:16]) in the next falling edge. It is suggested to use the fDIV\_CLK (TMCNTSRC (USCI\_BRGEN[5]) =1) as the counter source.

The CLKDIV (USCI\_BRGEN[25:16]) will be revised by BRDETITV (USCI\_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 (USCI\_BRGEN[25:16]) and DSCNT (USCI\_BRGEN[14:10]) as the same value (the value shall be among the rang of 0xF and 0x5 because the DSCNT is used to define the sample counter of each bit and the PDSCNT (USCI\_BRGEN[9:8]) is 0x0).

During the auto baud rate detection, the ABRDETIF (USCI\_PROTSTS[9]) and the BRDETITV (USCI\_PROTCTL [24:16]) will be updated after each falling edge of input signal and the auto baud rate pattern, 0x55, won't be received into the receiver buffer after the frame done. The bit of ABREN will be cleared by hardware after the 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 (USCI\_PROTSTS[11]) to indicate the error information of the auto baud rate detection. At this time, the user shall revise the value of CLKDIV and require the Host device to send the 0x55 pattern again.

According the limitation of timing measurement counter, the maximum auto baud rate detection is 0x1FE for BRDETTIV. The UART Auto Baud Rate Control is shown in Figure 6.24-5.



Figure 6.24-5 UART Auto Baud Rate Control

#### 6.24.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 deasserted.

The UART also provides nCTS flow control on transmitter. The nCTS is used to control the transmitted data is sent out when the nCTS is asserted.

#### 6.24.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 (USCI\_PROTCTL[1]) be set) when the STICKEN (USCI\_PROTCTL[26]) is set. For example, if the STICKEN is set to 1 and data sequence are 0x8015, 0x8033, 0x0055, 0x0033 and 0x80AA the transmitted parity of data 0x15, 0x33, 0x55 0x33 and 0xAA will be 1, 1, 0, 0 and 1.

The UART controller can also play as an RS-485 addressable slave, the protocol-related error of PARITYERR (USCI\_PROTSTS[5]) can be acted as the address bit detection when the PARITYEN (USCI\_PROTCTL[1]), EVENPARITY (USCI\_PROTCTL[2]) and STICKEN (USCI\_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.24.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 (USCI\_WKCTL [0]) and DATWKEN (USCI\_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 (USCI\_PROTCTL[14:11]) shall be set. These bits field of WAKECNT (USCI\_PROTCTL[14:11]) indicate how many clock cycle selected by fPDS\_CNT do the controller can get the 1st bit (start bit) when the device is wakeup from Power-down mode. The incoming data wake-wp is shown in Figure 6.24-6.



Figure 6.24-6 Incoming Data Wake-Up

**(b) nCTS pin wake-up**

When system is in power-down and both of the WKEN (USCI\_WKCTL [0]) and CTSWKEN (USCI\_PROTCTL[10]) are set, the toggle of nCTS pin can wake-up the system. The nCTS wake-wp is shown in Figure 6.24-7 and Figure 6.24-8.

**Case 1(nCTS transition from low to high):**

Figure 6.24-7 nCTS Wake-Up Case 1

**Case 2 (nCTS transition from high to low):**

Figure 6.24-8 nCTS Wake-Up Case 2

**6.24.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 USCI\_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 (USCI\_PROTSTS[6]) or PARITYERR (USCI\_PROTSTS[5]) are

two flags that are assigned to each received data word in the corresponding receiver buffer status registers.

In UART mode, the result of the parity check by the protocol-related error indication (0 = received parity bit equal to calculated parity value), and the result of frame check by the protocol-related error indication (0 = received stop bit equal to the format value '1'). This information is elaborated for each data frame.

The break error flag 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 (USCI\_PROTSTS[7:5]) bits.

#### **Auto Baud Rate Detection**

The auto baud rate interrupt, ABRDETIF (USCI\_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 (USCI\_PROTCTL[24:16]) and write into the baud rate generator register CLKDIV (USCI\_BRGEN[25:16]).

#### **Data Transfer Interrupt Handling**

The data transfer interrupts indicate events related to UART frame handling.

##### **Transmit Start Interrupt**

Bit TXSTIF (USCI\_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 USCI\_TXDAT.

##### **Transmitter Finished**

This interrupt indicates that the transmitter has completely finished all data in the buffer. Bit TXENDIF (USCI\_PROTSTS [2]) becomes set at the end of the last stop bit.

##### **Receiver Starts Interrupt**

Bit RXSTIF (USCI\_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 (USCI\_PROTSTS [4]) becomes set at the end of the last receive bit.

#### *6.24.5.12 Programming Example*

The following steps are used to configure the UART protocol setting and the data transmission.

1. Set FUNMODE (UUART\_CTL[2:0]) to 0x2 to select UART protocol.
2. Write baud rate generator register UUART\_BRGEN to select desired baud rate.
  - Set SPCLKSEL (UUART\_BRGEN[3:2]), PTCLKSEL (UUART\_BRGEN[1]) and RCLKSEL (UUART\_BRGEN[0]) to select the clock source.
  - Configure CLKDIV (UUART\_BRGEN[25:16]), DSCNT (UUART\_BRGEN[14:10]) and PDSCNT (UUART\_BRGEN[9:8]) to determine the baud rate divider.
3. Write line control register UUART\_LINECTL and protocol control register UUART\_PROTCTL to configure the transmission data format and UART protocol setting.
  - Program data field length in DWIDTH (UUART\_LINECTL[11:8]).
  - Enable parity bit and determine the parity bit type by setting EVENPARITY (UUART\_PROTCTL[2]) and PARITYEN (UUART\_PROTCTL[1]).

- Configure stop bit length by setting STOPB (UART\_PROTCTL[0]).
  - Enable LSB (UART\_LINECTL[0]) to select LSB first transmission for UART protocol.
  - Set EDGEDET (UART\_DATIN0[4:3]) to “10” to select the detected edge as falling edge for receiver start bit detection.
4. Set PROTEN (UART\_PROTCTL[31]) to 1 to enable UART protocol.
  5. Transmit and receive data.
    - Write transmit data register UART\_TXDAT to transmit data.
    - Wait until TXSTIF(UART\_PROTSTS[1]) is set and then user can write the next data in UART\_TXDAT.
    - When TXENDIF(UART\_PROTSTS[2]) is set, the transmit buffer is empty and the stop bit of the last data has been transmitted.
    - If RXENDIF(UART\_PROTSTS[4]) is set, the receiver has finished a data frame completely. User can get the data by reading receive data register UART\_RXDAT.

### 6.24.6 Register Map

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

| Register                                                | Offset                     | R/W | Description                                        | Reset Value |
|---------------------------------------------------------|----------------------------|-----|----------------------------------------------------|-------------|
| <b>USCI Base Address:</b>                               |                            |     |                                                    |             |
| <b>USCI<sub>n</sub>_BA = 0x400D_0000 + (0x1000 * n)</b> |                            |     |                                                    |             |
| n= 0, 1                                                 |                            |     |                                                    |             |
| <b>USCI_CTL</b>                                         | USCI <sub>n</sub> _BA+0x00 | R/W | USCI Control Register                              | 0x0000_0000 |
| <b>USCI_INTEN</b>                                       | USCI <sub>n</sub> _BA+0x04 | R/W | USCI Interrupt Enable Register                     | 0x0000_0000 |
| <b>USCI_BRGEN</b>                                       | USCI <sub>n</sub> _BA+0x08 | R/W | USCI Baud Rate Generator Register                  | 0x0000_3C00 |
| <b>USCI_DATINO</b>                                      | USCI <sub>n</sub> _BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0    | 0x0000_0000 |
| <b>USCI_CTLINO</b>                                      | USCI <sub>n</sub> _BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 0x0000_0000 |
| <b>USCI_CLKIN</b>                                       | USCI <sub>n</sub> _BA+0x28 | R/W | USCI Input Clock Signal Configuration Register     | 0x0000_0000 |
| <b>USCI_LINECTL</b>                                     | USCI <sub>n</sub> _BA+0x2C | R/W | USCI Line Control Register                         | 0x0000_0000 |
| <b>USCI_TXDAT</b>                                       | USCI <sub>n</sub> _BA+0x30 | W   | USCI Transmit Data Register                        | 0x0000_0000 |
| <b>USCI_RXDAT</b>                                       | USCI <sub>n</sub> _BA+0x34 | R   | USCI Receive Data Register                         | 0x0000_0000 |
| <b>USCI_BUFCTL</b>                                      | USCI <sub>n</sub> _BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register      | 0x0000_0000 |
| <b>USCI_BUFSTS</b>                                      | USCI <sub>n</sub> _BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register       | 0x0000_0101 |
| <b>USCI_PDMACTL</b>                                     | USCI <sub>n</sub> _BA+0x40 | R/W | USCI PDMA Control Register                         | 0x0000_0000 |
| <b>USCI_WKCTL</b>                                       | USCI <sub>n</sub> _BA+0x54 | R/W | USCI Wake-up Control Register                      | 0x0000_0000 |
| <b>USCI_WKSTS</b>                                       | USCI <sub>n</sub> _BA+0x58 | R/W | USCI Wake-up Status Register                       | 0x0000_0000 |
| <b>USCI_PROTCTL</b>                                     | USCI <sub>n</sub> _BA+0x5C | R/W | USCI Protocol Control Register                     | 0x0000_0000 |
| <b>USCI_PROTIEN</b>                                     | USCI <sub>n</sub> _BA+0x60 | R/W | USCI Protocol Interrupt Enable Register            | 0x0000_0000 |
| <b>USCI_PROTSTS</b>                                     | USCI <sub>n</sub> _BA+0x64 | R/W | USCI Protocol Status Register                      | 0x0000_0000 |

### 6.24.7 Register Description

#### USCI Control Register (USCI\_CTL)

| Register | Offset         | R/W | Description           |  |  |  |  | Reset Value |
|----------|----------------|-----|-----------------------|--|--|--|--|-------------|
| USCI_CTL | USCIIn_BA+0x00 | R/W | USCI Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [2:0]  | FUNMODE     | <p><b>Function Mode</b></p> <p>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.</p> <p>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<sup>2</sup>C protocol is selected.</p> <p><b>Note:</b> Other bit combinations are reserved.</p> |

USCI Interrupt Enable Register (USCI\_INTEN)

| Register   | Offset         | R/W | Description                    |  |  |  | Reset Value |
|------------|----------------|-----|--------------------------------|--|--|--|-------------|
| USCI_INTEN | USCIIn_BA+0x04 | R/W | USCI Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                         |
| [4]    | RXENDIEN    | <p><b>Receive End Interrupt Enable Bit</b><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.</p>           |
| [3]    | RXSTIEN     | <p><b>Receive Start Interrupt Enable Bit</b><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.</p>      |
| [2]    | TXENDIEN    | <p><b>Transmit End Interrupt Enable Bit</b><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.</p> |
| [1]    | TXSTIEN     | <p><b>Transmit Start Interrupt Enable Bit</b><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.</p>  |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                         |

USCI Baud Rate Generator Register (USCI\_BRGEN)

| Register   | Offset         | R/W | Description                       |  |  |  | Reset Value |
|------------|----------------|-----|-----------------------------------|--|--|--|-------------|
| USCI_BRGEN | USCIIn_BA+0x08 | R/W | USCI Baud Rate Generator Register |  |  |  | 0x0000_3C00 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [25:16] | <b>CLKDIV</b>   | <p><b>Clock Divider</b><br/> This bit field defines the ratio between the protocol clock frequency <math>f_{PROT\_CLK}</math> and the clock divider frequency <math>f_{DIV\_CLK}</math> (<math>f_{DIV\_CLK} = f_{PROT\_CLK} / (\text{CLKDIV} + 1)</math> ).</p> <p><b>Note:</b> In UART function, it can be updated by hardware in the 4<sup>th</sup> falling edge of the input data 0x55 when the auto baud rate function (ABREN(USCI_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 BRDETTIV (USCI_PROTCTL[24:16]) to calculate the precise baud rate.</p> |
| [15]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [14:10] | <b>DSCNT</b>    | <p><b>Denominator for Sample Counter</b><br/> This bit field defines the divide ratio of the sample clock <math>f_{SAMP\_CLK}</math>.<br/> The divided frequency <math>f_{DS\_CNT} = f_{PDS\_CNT} / (\text{DSCNT} + 1)</math>.</p> <p><b>Note:</b> 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.</p>                                                                                                                                                                                                                                                           |
| [9:8]   | <b>PDSCNT</b>   | <p><b>Pre-divider for Sample Counter</b><br/> This bit field defines the divide ratio of the clock division from sample clock <math>f_{SAMP\_CLK}</math>. The divided frequency <math>f_{PDS\_CNT} = f_{SAMP\_CLK} / (\text{PDSCNT} + 1)</math>.</p>                                                                                                                                                                                                                                                                                                                                                                                              |
| [7:6]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [5]     | <b>TMCNTSRC</b> | <p><b>Timing Measurement Counter Clock Source Selection</b><br/> 0 = Timing measurement counter with <math>f_{PROT\_CLK}</math>.<br/> 1 = Timing measurement counter with <math>f_{DIV\_CLK}</math>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [4]     | <b>TMCNTEN</b>  | <p><b>Timing Measurement Counter Enable Bit</b><br/> This bit enables the 10-bit timing measurement counter.<br/> 0 = Timing measurement counter is Disabled.<br/> 1 = Timing measurement counter is Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [3:2]   | <b>SPCLKSEL</b> | <p><b>Sample Clock Source Selection</b><br/> This bit field used for the clock source selection of a sample clock (<math>f_{SAMP\_CLK}</math>) for the protocol processor.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|     |                 |                                                                                                                                                                                                                                                                                  |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | <p>00 = <math>f_{SAMP\_CLK} = f_{DIV\_CLK}</math>.<br/>01 = <math>f_{SAMP\_CLK} = f_{PROT\_CLK}</math>.<br/>10 = <math>f_{SAMP\_CLK} = f_{SCLK}</math>.<br/>11 = <math>f_{SAMP\_CLK} = f_{REF\_CLK}</math>.</p>                                                                  |
| [1] | <b>PTCLKSEL</b> | <p><b>Protocol Clock Source Selection</b><br/>This bit selects the source signal of protocol clock (<math>f_{PROT\_CLK}</math>).<br/>0 = Reference clock <math>f_{REF\_CLK}</math>.<br/>1 = <math>f_{REF\_CLK2}</math> (its frequency is half of <math>f_{REF\_CLK}</math>).</p> |
| [0] | <b>RCLKSEL</b>  | <p><b>Reference Clock Source Selection</b><br/>This bit selects the source signal of reference clock (<math>f_{REF\_CLK}</math>).<br/>0 = Peripheral device clock <math>f_{PCLK}</math>.<br/>1 = Reserved.</p>                                                                   |

**USCI Input Data Signal Configuration (USCI\_DATIN0)**

| Register           | Offset         | R/W | Description                                     |  |  |  | Reset Value |
|--------------------|----------------|-----|-------------------------------------------------|--|--|--|-------------|
| <b>USCI_DATIN0</b> | USCIIn_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0 |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [4:3]  | <b>EDGEDET</b>  | <p><b>Input Signal Edge Detection Mode</b><br/> This bit field selects which edge activates 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/> <b>Note:</b> In UART function mode, it is suggested to set this bit field as 10.</p> |
| [2]    | <b>ININV</b>    | <p><b>Input Signal Inverse Selection</b><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.</p>                                                                                                                                                                                                                                                         |
| [1]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [0]    | <b>SYNCSEL</b>  | <p><b>Input Signal Synchronization Selection</b><br/> This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.<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.</p>                                                                                              |

USCI Input Control Signal Configuration (USCI\_CTLIN0)

| Register    | Offset         | R/W | Description                                        |  |  |  | Reset Value |
|-------------|----------------|-----|----------------------------------------------------|--|--|--|-------------|
| USCI_CTLIN0 | USCIIn_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                          |
| [2]    | ININV       | <b>Input Signal Inverse Selection</b><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     | <b>Input Synchronization Signal Selection</b><br>This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.<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 (USCI\_CLKIN)

| Register   | Offset         | R/W | Description                                    |  |  |  |  | Reset Value |
|------------|----------------|-----|------------------------------------------------|--|--|--|--|-------------|
| USCI_CLKIN | USCIIn_BA+0x28 | R/W | USCI Input Clock Signal Configuration Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                  |
| [0]    | SYNCSEL     | <p><b>Input Synchronization Signal Selection</b></p> <p>This bit selects if the un-synchronized input signal or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.</p> <p>0 = The un-synchronized signal can be taken as input for the data shift unit.</p> <p>1 = The synchronized signal can be taken as input for the data shift unit.</p> |

USCI Line Control Register (USCI\_LINECTL)

| Register     | Offset        | R/W | Description                |  |  |  | Reset Value |
|--------------|---------------|-----|----------------------------|--|--|--|-------------|
| USCI_LINECTL | USCIx_BA+0x2C | R/W | USCI Line Control Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [11:8]  | DWIDTH      | <p><b>Word Length of Transmission</b></p> <p>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.</p> <p>0x0: The data word contains 16 bits located at bit positions [15:0].</p> <p>0x1: Reserved.</p> <p>0x2: Reserved.</p> <p>0x3: Reserved.</p> <p>0x4: The data word contains 4 bits located at bit positions [3:0].</p> <p>0x5: The data word contains 5 bits located at bit positions [4:0].</p> <p>...</p> <p>0xF: The data word contains 15 bits located at bit positions [14:0].</p> <p><b>Note:</b> In UART protocol, the length can be configured as 6~13 bits.</p> |
| [7]     | CTLOINV     | <p><b>Control Signal Output Inverse Selection</b></p> <p>This bit defines the relation between the internal control signal and the output control signal.</p> <p>0 = No effect.</p> <p>1 = The control signal will be inverted before its output.</p> <p><b>Note:</b> In UART protocol, the control signal means nRTS signal.</p>                                                                                                                                                                                                                                                                                                                                                                                             |
| [6]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [5]     | DATOINV     | <p><b>Data Output Inverse Selection</b></p> <p>This bit defines the relation between the internal shift data value and the output data signal of USCIx_DAT1 pin.</p> <p>0 = The value of USCIx_DAT1 is equal to the data shift register.</p> <p>1 = The value of USCIx_DAT1 is the inversion of data shift register.</p>                                                                                                                                                                                                                                                                                                                                                                                                      |
| [4:1]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| [0] | LSB | <b>LSB First Transmission Selection</b>                                                                                 |
|-----|-----|-------------------------------------------------------------------------------------------------------------------------|
|     |     | 0 = The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is transmitted/received first. |
|     |     | 1 = The LSB, the bit 0 of data buffer, will be transmitted/received first.                                              |

**USCI Transmit Data Register (USCI\_TXDAT)**

| Register   | Offset         | R/W | Description                 | Reset Value |
|------------|----------------|-----|-----------------------------|-------------|
| USCI_TXDAT | USCIIn_BA+0x30 | W   | USCI Transmit Data Register | 0x0000_0000 |

|          |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| Reserved |    |    |    |    |    |    |    |
| 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |    |    |    |    |    |    |    |
| 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       | <b>Transmit Data</b><br>Software can use this bit field to write 16-bit transmit data for transmission. |

**USCI Receive Data Register (USCI\_RXDAT)**

| Register   | Offset         | R/W | Description                |  |  |  | Reset Value |
|------------|----------------|-----|----------------------------|--|--|--|-------------|
| USCI_RXDAT | USCIIn_BA+0x34 | R   | USCI Receive Data Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                       |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                             |
| [15:0]  | RXDAT       | <p><b>Received Data</b></p> <p>This bit field monitors the received data which stored in receive data buffer.</p> <p><b>Note:</b> RXDAT[15:13] indicate the same frame status of BREAK, FRMERR and PARITYERR (USCI_PROTSTS[7:5]).</p> |

**USCI Transmitter/Receive Buffer Control Register (USCI\_BUFCCTL)**

| Register     | Offset         | R/W | Description                                   |  |  |  |  | Reset Value |
|--------------|----------------|-----|-----------------------------------------------|--|--|--|--|-------------|
| USCI_BUFCCTL | USCIIn_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                   |
| [17]    | RXRST       | <p><b>Receive Reset</b><br/>           0 = No effect.<br/>           1 = Reset the receive-related counters, state machine, and the content of receive shift register and data buffer.<br/> <b>Note1:</b> It is cleared automatically after one PCLK cycle.<br/> <b>Note2:</b> It is suggested to check the RXBUSY (USCI_PROTSTS[10]) before this bit will be set to 1.</p> |
| [16]    | TXRST       | <p><b>Transmit Reset</b><br/>           0 = No effect.<br/>           1 = Reset the transmit-related counters, state machine, and the content of transmit shift register and data buffer.<br/> <b>Note:</b> It is cleared automatically after one PCLK cycle.</p>                                                                                                           |
| [15]    | RXCLR       | <p><b>Clear Receive Buffer</b><br/>           0 = 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/> <b>Note:</b> It is cleared automatically after one PCLK cycle.</p>                                 |
| [14]    | RXOVIEN     | <p><b>Receive Buffer Overrun Error Interrupt Enable Bit</b><br/>           0 = Receive overrun interrupt Disabled.<br/>           1 = Receive overrun interrupt Enabled.</p>                                                                                                                                                                                                |
| [13:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                   |
| [7]     | TXCLR       | <p><b>Clear Transmit Buffer</b><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/> <b>Note:</b> It is cleared automatically after one PCLK cycle.</p>                               |

[6:0]

Reserved

Reserved.

**USCI Transmit/Receive Buffer Status Register (USCI\_BUFSTS)**

| Register    | Offset         | R/W | Description                                  |  |  |  |  | Reset Value |
|-------------|----------------|-----|----------------------------------------------|--|--|--|--|-------------|
| USCI_BUFSTS | USCIIn_BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register |  |  |  |  | 0x0000_0101 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                             |
| [9]     | <b>TXFULL</b>   | <b>Transmit Buffer Full Indicator</b><br>0 = Transmit buffer is not full.<br>1 = Transmit buffer is full.                                                                                                                                                                                                                                                                                                             |
| [8]     | <b>TXEMPTY</b>  | <b>Transmit Buffer Empty Indicator</b><br>0 = Transmit buffer is not empty.<br>1 = Transmit buffer is empty.                                                                                                                                                                                                                                                                                                          |
| [7:4]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                             |
| [3]     | <b>RXOVIF</b>   | <b>Receive Buffer Over-run Error Interrupt Status</b><br>This bit indicates that a receive buffer overrun error event has been detected. If RXOVEN (USCI_BUFCCTL[14]) is enabled, the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit.<br>0 = A receive buffer overrun error event has not been detected.<br>1 = A receive buffer overrun error event has been detected. |
| [2]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                             |
| [1]     | <b>RXFULL</b>   | <b>Receive Buffer Full Indicator</b><br>0 = Receive buffer is not full.<br>1 = Receive buffer is full.                                                                                                                                                                                                                                                                                                                |
| [0]     | <b>RXEMPTY</b>  | <b>Receive Buffer Empty Indicator</b><br>0 = Receive buffer is not empty.<br>1 = Receive buffer is empty.                                                                                                                                                                                                                                                                                                             |

**USCI PDMA Control Register (USCI\_PDMACTL)**

| Register     | Offset         | R/W | Description                |  |  |  | Reset Value |
|--------------|----------------|-----|----------------------------|--|--|--|-------------|
| USCI_PDMACTL | USCIIn_BA+0x40 | R/W | USCI 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 |    |    |    | PDMAEN | RXPDMAEN | TXPDMAEN | PDMARST |

| Bits   | Description |                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                    |
| [3]    | PDMAEN      | <b>PDMA Mode Enable Bit</b><br>0 = PDMA function Disabled.<br>1 = PDMA function Enabled.                                     |
| [2]    | RXPDMAEN    | <b>PDMA Receive Channel Available</b><br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.           |
| [1]    | TXPDMAEN    | <b>PDMA Transmit Channel Available</b><br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled.        |
| [0]    | PDMARST     | <b>PDMA Reset</b><br>0 = No effect.<br>1 = Reset the USCI's PDMA control logic. This bit will be cleared to 0 automatically. |

**USCI Wake-up Control Register (USCI\_WKCTL)**

| Register   | Offset         | R/W | Description                   |  |  |  | Reset Value |
|------------|----------------|-----|-------------------------------|--|--|--|-------------|
| USCI_WKCTL | USCIIn_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 |    |    |    |    | PDBOPT | Reserved | WKEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [2]    | PDBOPT      | <b>Power Down Blocking Option</b><br>0 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, MCU will stop the transfer and enter Power-down mode immediately.<br>1 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, the on-going transfer will not be stopped and MCU will enter idle mode immediately. |
| [1]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [0]    | WKEN        | <b>Wake-up Enable Bit</b><br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                                                                                                                                                                                                                                                                              |

USCI Wake-up Status Register (USCI\_WKSTS)

| Register   | Offset         | R/W | Description                  |  |  |  | Reset Value |
|------------|----------------|-----|------------------------------|--|--|--|-------------|
| USCI_WKSTS | USCIIn_BA+0x58 | R/W | USCI Wake-up Status Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                        |
| [0]    | WKF         | <b>Wake-up Flag</b><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 (USCI\_PROTCTL)

| Register     | Offset         | R/W | Description                    |  |  |  | Reset Value |
|--------------|----------------|-----|--------------------------------|--|--|--|-------------|
| USCI_PROTCTL | USCIIn_BA+0x5C | R/W | USCI Protocol Control Register |  |  |  | 0x0000_0000 |

|           |          |            |            |           |            |          |           |
|-----------|----------|------------|------------|-----------|------------|----------|-----------|
| 31        | 30       | 29         | 28         | 27        | 26         | 25       | 24        |
| PROTEN    | Reserved | BCEN       | Reserved   | Reserved  | STICKEN    | Reserved | BRDESTITV |
| 23        | 22       | 21         | 20         | 19        | 18         | 17       | 16        |
| BRDESTITV |          |            |            |           |            |          |           |
| 15        | 14       | 13         | 12         | 11        | 10         | 9        | 8         |
| Reserved  | WAKECNT  |            |            |           | CTSWKEN    | DATWKEN  | Reserved  |
| 7         | 6        | 5          | 4          | 3         | 2          | 1        | 0         |
| Reserved  | ABREN    | RTSAUDIREN | CTS AUTOEN | RTSAUTOEN | EVENPARITY | PARITYEN | STOPB     |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | PROTEN      | <b>UART Protocol Enable Bit</b><br>0 = UART Protocol Disabled.<br>1 = UART Protocol Enabled.                                                                                                                                                                                                                                                                                                                                                                                                      |
| [30]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [29]    | BCEN        | <b>Transmit Break Control Enable Bit</b><br>0 = Transmit Break Control Disabled.<br>1 = Transmit Break Control Enabled.<br><b>Note:</b> 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 transmitter logic.                                                                                                                                                                          |
| [27]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [26]    | STICKEN     | <b>Stick Parity Enable Bit</b><br>0 = Stick parity Disabled.<br>1 = Stick parity Enabled.<br><b>Note:</b> Refer to RS-485 Support section for detailed information.                                                                                                                                                                                                                                                                                                                               |
| [25]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [24:16] | BRDESTITV   | <b>Baud Rate Detection Interval</b><br>This bit fields indicate how many clock cycle selected by TMCNTSRC (USCI_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 0x55). The user can read the value to know the current input baud rate of the bus whenever the ABRDETIF (USCI_PROTCTL[9]) is set.<br><b>Note:</b> This bit can be cleared to 0 by software writing '0' to the BRDESTITV. |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [14:11] | WAKECNT     | <b>Wake-up Counter</b><br>These bits field indicate how many clock cycle selected by $f_{PDS\_CNT}$ do the slave can get the 1 <sup>st</sup> bit (start bit) when the device is wake-up from Power-down mode.                                                                                                                                                                                                                                                                                     |
| [10]    | CTSWKEN     | <b>nCTS Wake-up Mode Enable Bit</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|     |            |                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |            | 0 = nCTS wake-up mode Disabled.<br>1 = nCTS wake-up mode Enabled.                                                                                                                                                                                                                                                                                                                                                               |
| [9] | DATWKEN    | <b>Data Wake-up Mode Enable Bit</b><br>0 = Data wake-up mode Disabled.<br>1 = Data wake-up mode Enabled.                                                                                                                                                                                                                                                                                                                        |
| [6] | ABREN      | <b>Auto-baud Rate Detect Enable Bit</b><br>0 = Auto-baud rate detect function Disabled.<br>1 = Auto-baud rate detect function Enabled.<br><b>Note:</b> When the auto - baud rate detect operation finishes, hardware will clear this bit. The associated interrupt ABRDETIF (USCI_PROTST[9]) will be generated (If ARBIEN (USCI_PROTIEN [1]) is enabled).                                                                       |
| [5] | RTSAUDIREN | <b>nRTS Auto Direction Enable Bit</b><br>When nRTS auto direction is enabled, if the transmitted bytes in the TX buffer is empty, the UART asserted nRTS signal automatically.<br>0 = nRTS auto direction control Disabled.<br>1 = nRTS auto direction control Enabled.<br><b>Note 1:</b> This bit is used for nRTS auto direction control for RS485.<br><b>Note 2:</b> This bit has effect only when the RTSAUTOEN is not set. |
| [4] | CTSAUTOEN  | <b>nCTS Auto-flow Control Enable Bit</b><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).<br>0 = nCTS auto-flow control Disabled.<br>1 = nCTS auto-flow control Enabled.                                                                                                                                 |
| [3] | RTSAUTOEN  | <b>nRTS Auto-flow Control Enable Bit</b><br>When nRTS auto-flow is enabled, if the receiver buffer is full (RXFULL (USCI_BUFSTS[1] =1), the UART will de-assert nRTS signal.<br>0 = nRTS auto-flow control Disabled.<br>1 = nRTS auto-flow control Enabled.<br><b>Note:</b> This bit has effect only when the RTSAUDIREN is not set.                                                                                            |
| [2] | EVENPARITY | <b>Even Parity Enable Bit</b><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><b>Note:</b> This bit has effect only when PARITYEN is set.                                                                                                                                                                                   |
| [1] | PARITYEN   | <b>Parity Enable Bit</b><br>This bit defines the parity bit is enabled in an UART frame.<br>0 = The parity bit Disabled.<br>1 = The parity bit Enabled.                                                                                                                                                                                                                                                                         |
| [0] | STOPB      | <b>Stop Bits</b><br>This bit defines the number of stop bits in an UART frame.<br>0 = The number of stop bits is 1.<br>1 = The number of stop bits is 2.                                                                                                                                                                                                                                                                        |

**USCI Protocol Interrupt Enable Register – UART (USCI\_PROTIEN)**

| Register            | Offset         | R/W | Description                             |  |  |  | Reset Value |
|---------------------|----------------|-----|-----------------------------------------|--|--|--|-------------|
| <b>USCI_PROTIEN</b> | USCIIn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                                          |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                |
| [2]    | <b>RLSIEN</b>   | <p><b>Receive Line Status Interrupt Enable Bit</b><br/>           0 = Receive line status interrupt Disabled.<br/>           1 = Receive line status interrupt Enabled.<br/> <b>Note:</b> USCI_PROTSTS[7:5] indicates the current interrupt event for receive line status interrupt.</p> |
| [1]    | <b>ABRIEN</b>   | <p><b>Auto-baud Rate Interrupt Enable Bit</b><br/>           0 = Auto-baud rate interrupt Disabled.<br/>           1 = Auto-baud rate interrupt Enabled.</p>                                                                                                                             |
| [0]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                |

**USCI Protocol Status Register – UART (USCI\_PROTSTS)**

| Register     | Offset         | R/W | Description                   |  |  |  | Reset Value |
|--------------|----------------|-----|-------------------------------|--|--|--|-------------|
| USCI_PROTSTS | USCIIn_BA+0x64 | R/W | USCI Protocol Status Register |  |  |  | 0x0000_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       | <p><b>nCTS Pin Status (Read Only)</b><br/>           This bit used to monitor the current status of nCTS pin input.<br/>           0 = nCTS pin input is low level voltage logic state.<br/>           1 = nCTS pin input is high level voltage logic state.</p>                                                                                                                                                                                                                                                                                                                          |
| [16]    | CTSSYNCLV   | <p><b>nCTS Synchronized Level Status (Read Only)</b><br/>           This bit used to indicate the current status of the internal synchronized nCTS signal.<br/>           0 = The internal synchronized nCTS is low.<br/>           1 = The internal synchronized nCTS is high.</p>                                                                                                                                                                                                                                                                                                       |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [11]    | ABERRSTS    | <p><b>Auto-baud Rate Error Status</b><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 (USCI_BRGEN[25:16]) value and enable ABREN (USCI_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/> <b>Note 1:</b> This bit is set at the same time of ABRDETIF.<br/> <b>Note 2:</b> This bit can be cleared by writing "1" to ABRDETIF or ABERRSTS.</p> |
| [10]    | RXBUSY      | <p><b>RX Bus Status Flag (Read Only)</b><br/>           This bit indicates the busy status of the receiver.<br/>           0 = The receiver is Idle.<br/>           1 = The receiver is BUSY.</p>                                                                                                                                                                                                                                                                                                                                                                                         |
| [9]     | ABRDETIF    | <p><b>Auto-baud Rate Interrupt Flag</b><br/>           This bit is set when auto-baud rate detection is done among the falling edge of the input</p>                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                  | <p>data. If the ABRIEN (USCI_PROTCTL[6]) is set, the auto-baud rate interrupt will be generated. This bit can be set 4 times when the input data pattern is 0x55 and it is cleared before the next falling edge of the input bus.</p> <p>0 = Auto-baud rate detect function is not done.<br/>1 = One Bit auto-baud rate detect function is done.</p> <p><b>Note:</b> This bit can be cleared by writing "1" to it.</p>                                      |
| [8] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [7] | <b>BREAK</b>     | <p><b>Break Flag</b></p> <p>This bit is set to logic 1 whenever the received data input (RX) is held in the "spacing state" (logic 0) for longer than a full word transmission time (that is, the total time of "start bit" + data bits + parity + stop bits).</p> <p>0 = No Break is generated.<br/>1 = Break is generated in the receiver bus.</p> <p><b>Note:</b> This bit can be cleared by writing "1" among the BREAK, FRMERR and PARITYERR bits.</p> |
| [6] | <b>FRMERR</b>    | <p><b>Framing Error Flag</b></p> <p>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).</p> <p>0 = No framing error is generated.<br/>1 = Framing error is generated.</p> <p><b>Note:</b> This bit can be cleared by writing "1" among the BREAK, FRMERR and PARITYERR bits.</p>                                          |
| [5] | <b>PARITYERR</b> | <p><b>Parity Error Flag</b></p> <p>This bit is set to logic 1 whenever the received character does not have a valid "parity bit".</p> <p>0 = No parity error is generated.<br/>1 = Parity error is generated.</p> <p><b>Note:</b> This bit can be cleared by writing "1" among the BREAK, FRMERR and PARITYERR bits.</p>                                                                                                                                    |
| [4] | <b>RXENDIF</b>   | <p><b>Receive End Interrupt Flag</b></p> <p>0 = A receive finish interrupt status has not occurred.<br/>1 = A receive finish interrupt status has occurred.</p> <p><b>Note:</b> It is cleared by software writing 1 into this bit.</p>                                                                                                                                                                                                                      |
| [3] | <b>RXSTIF</b>    | <p><b>Receive Start Interrupt Flag</b></p> <p>0 = A receive start interrupt status has not occurred.<br/>1 = A receive start interrupt status has occurred.</p> <p><b>Note:</b> It is cleared by software writing 1 into this bit.</p>                                                                                                                                                                                                                      |
| [2] | <b>TXENDIF</b>   | <p><b>Transmit End Interrupt Flag</b></p> <p>0 = A transmit end interrupt status has not occurred.<br/>1 = A transmit end interrupt status has occurred.</p> <p><b>Note:</b> It is cleared by software writing 1 into this bit.</p>                                                                                                                                                                                                                         |
| [1] | <b>TXSTIF</b>    | <p><b>Transmit Start Interrupt Flag</b></p> <p>0 = A transmit start interrupt status has not occurred.<br/>1 = A transmit start interrupt status has occurred.</p> <p><b>Note 1:</b> It is cleared by software writing one into this bit.<br/><b>Note 2:</b> Used for user to load next transmit data when there is no data in transmit buffer.</p>                                                                                                         |
| [0] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## 6.25 USCI - SPI Mode

### 6.25.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-directional 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 (USCI\_CTL[2:0]) = 0x1

This SPI protocol can operate as master or Slave mode by setting the SLAVE (USCI\_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.25-1 SPI Master Mode Application Block Diagram



Figure 6.25-2 SPI Slave Mode Application Block Diagram

### 6.25.2 Features

- Supports Master or Slave mode operation (the maximum frequency -- Master =  $f_{PCLK} / 2$ , Slave <  $f_{PCLK} / 5$ )
- Configurable bit length of a transfer word from 4 to 16-bit
- Supports one transmit buffer and two receive buffers for data payload
- Supports MSB first or LSB first transfer sequence
- Supports Word Suspend function

- Supports 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.25.3 Block Diagram



Figure 6.25-3 USCI SPI Mode Block Diagram

### 6.25.4 Basic Configuration

#### 6.25.4.1 USCI0 SPI Basic Configurations

- Clock Source Configuration
  - Enable USCI0 peripheral clock in **USCI0CKEN** (CLK\_APBCLK1[8]).
  - Enable USCI0\_SPI function on **USCI\_CTL[2:0]** register, **USCI\_CTL[2:0]=3'b001**
- Reset Configuration
  - Reset USCI0 controller in **USCI0RST** (SYS\_IPRST2[8]).
- Pin Configuration

| Group | Pin Name  | GPIO  | MFP  |
|-------|-----------|-------|------|
| USCI0 | USCI0_CLK | PD.0  | MFP3 |
|       |           | PB.12 | MFP5 |
|       |           | PA.11 | MFP6 |
|       |           | PE.2  | MFP7 |

|            |       |      |
|------------|-------|------|
| USCI0_CTL0 | PD.4  | MFP3 |
|            | PC.14 | MFP5 |
|            | PC.13 | MFP6 |
|            | PE.6  | MFP7 |
| USCI0_DAT0 | PD.1  | MFP3 |
|            | PB.13 | MFP5 |
|            | PA.10 | MFP6 |
|            | PE.3  | MFP7 |
| USCI0_DAT1 | PD.2  | MFP3 |
|            | PB.14 | MFP5 |
|            | PA.9  | MFP6 |
|            | PE.4  | MFP7 |

#### 6.25.4.2 USCI1 SPI Basic Configurations

- Clock source Configuration
  - Enable USCI1 peripheral clock in USCI1CKEN (CLK\_APBCLK1[9]).
  - Enable USCI1\_SPI function USCI\_CTL[2:0] register, USCI\_CTL[2:0]=3'b001
- Reset Configuration
  - Reset USCI1 controller in USCI1RST (SYS\_IPRST2[9]).
- Pin Configuration

| Group | Pin Name   | GPIO        | MFP  |
|-------|------------|-------------|------|
| USCI1 | USCI1_CLK  | PB.8        | MFP4 |
|       |            | PD.7, PE.12 | MFP6 |
|       |            | PB.1        | MFP8 |
|       | USCI1_CTL0 | PB.10       | MFP4 |
|       |            | PD.3, PE.9  | MFP6 |
|       |            | PB.5        | MFP8 |
|       | USCI1_DAT0 | PB.7        | MFP4 |
|       |            | PD.5, PE.10 | MFP6 |
|       |            | PB.2        | MFP8 |
|       | USCI1_DAT1 | PB.6        | MFP4 |
|       |            | PD.6, PE.11 | MFP6 |
|       |            | PB.3        | MFP8 |

#### 6.25.5 Functional Description

##### 6.25.5.1 USCI Common Function Description

Please refer to section 6.23.4 for detailed information.

### 6.25.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 end of a data transfer, and the master device can use it to enable the transmitting or receiving operations of Slave device. Slave device receives the SPI bus clock and optionally a slave select signal for data transaction. The signals for SPI communication are shown below.

| SPI Mode                     | Receive Data             | Transmit Data            | Serial Bus Clock       | Slave Select           |
|------------------------------|--------------------------|--------------------------|------------------------|------------------------|
| Full-duplex SPI Master       | SPI_MISO<br>(USCIx_DAT1) | SPI_MOSI<br>(USCIx_DAT0) | SPI_CLK<br>(USCIx_CLK) | SPI_SS<br>(USCIx_CTL0) |
| Full-duplex SPI Slave        | SPI_MOSI<br>(USCIx_DAT0) | SPI_MISO<br>(USCIx_DAT1) | SPI_CLK<br>(USCIx_CLK) | SPI_SS<br>(USCIx_CTL0) |
| Half-duplex SPI Master/Slave | SPI_MOSI<br>(USCIx_DAT0) | SPI_MOSI<br>(USCIx_DAT0) | SPI_CLK<br>(USCIx_CLK) | SPI_SS<br>(USCIx_CTL0) |

SPI Communication Signals



Figure 6.25-44-Wire Full-Duplex SPI Communication Signals (Master Mode)



Figure 6.25-54-Wire Full-Duplex SPI Communication Signals (Slave Mode)

#### 6.25.5.3 Serial Bus Clock Configuration

The USCI controller needs the peripheral clock to drive the USCI logic unit to perform the data transfer. The peripheral clock frequency is equal to PCLK frequency.

In Master mode, the frequency of the SPI bus clock is determined by protocol-relative clock generator. In general, the SPI bus clock is denoted as SPI clock. The frequency of SPI clock is half of  $f_{SAMP\_CLK}$ , which can be selected by SPCLKSEL (USCI\_BRGEN[3:2]). Refer to 6.23.4 for details of protocol-relative clock generator.

In Slave mode, the SPI bus clock is provided by an off-chip Master device. The peripheral clock frequency,  $f_{PCLK}$ , of SPI Slave device must be 5-times faster than the serial bus clock rate of the SPI Master device connected together (i.e. the clock rate of serial bus clock < 1/5 peripheral clock  $f_{PCLK}$  in Slave mode).

In SPI protocol, SCLKMODE (USCI\_PROTCTL[7:6]) defines not only the idle state of serial bus clock but also the serial clock edge used for transmit and receive data. Both Master and Slave devices on the same communication bus should have the same SCLKMODE configuration. The four kinds of serial bus clock configuration are shown below.

| SCLKMODE [1:0] | SPI Clock Idle State | Transmit Timing | Receive Timing |
|----------------|----------------------|-----------------|----------------|
| 0x0            | Low                  | Falling edge    | Rising edge    |
| 0x1            | Low                  | Rising edge     | Falling edge   |
| 0x2            | High                 | Rising edge     | Falling edge   |
| 0x3            | High                 | Falling edge    | Rising edge    |

Table 6.25-1 Serial Bus Clock Configuration



Figure 6.25-6 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x0)



Figure 6.25-7 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x1)



Figure 6.25-8 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x2)



Figure 6.25-9 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x3)

#### 6.25.5.4 Slave Select Signal

The slave selection signal of SPI protocol is active high by default. In SPI Master mode, the USCI controller can drive the control signal to off-chip SPI Slave device through slave select pin SPI\_SS (USCIx\_CTL0). In SPI Slave mode, the received slave select signal can be inverted by ININV (USCI\_CTLIN0[2]).

If the slave select signal of external SPI Master device is low active, the ININV (USCI\_CTLIN[2]) setting of slave device should be set to 1 for the inversion of input control signal. If USCI operates as SPI Master mode, the output slave select inversion CTLOINV (USCI\_LINECTL[7]) is also needed to

set as 1 for the external SPI Slave device whose slave select signal is active low.

The duration between the slave select active edge and the first SPI clock input edge shall over 2 USCI peripheral clock cycles.

The input slave select signal of SPI Slave has to be keep inactive for at least 2 USCI peripheral clock cycles between two consecutive frames in order to correctly detect the end of a frame.

#### 6.25.5.5 Transmit and Receive Data

The bit length of a transmit/receive data word in SPI protocol of USCI controller is defined in DWIDTH (USCI\_LINECTL[11:8]), and it can be configured up to 16-bit length for transmitting and receiving data in SPI communication.

The LSB bit (USCI\_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.25-1016-bit Data Length in One Word Transaction with MSB First Format

#### 6.25.5.6 Word Suspend

SUSPITV (USCI\_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 (USCI\_PROTCTL[11:8]) is 0x3 (3.5 SPI clock cycles).



Figure 6.25-11 Word Suspend Interval between Two Transaction Words

### 6.25.5.7 Automatic Slave Select Function

AUTOSS (USCI\_PROTCTL[3]) is used for SPI Master mode to enable the automatic slave select function. If the bit AUTOSS (USCI\_PROTCTL[3]) is set, the slave select signal will be generated automatically and the setting value of SS (USCI\_PROTCTL[2]) will not affect the output slave select (through USCIx\_CTL0 line). This means that the slave select signal will be asserted by the USCI controller when the SPI data transfer is started by writing to the transmit buffer. And, it will be deasserted after either all transaction is finished or one word transaction done if the value of SUSPITV (USCI\_PROTCTL[11:8]) is equal to or greater than 3.

If the AUTOSS bit (USCI\_PROTCTL[3]) is cleared, the slave select on USCIx\_CTL0 pin will be asserted/de-asserted by setting/clearing the SS (USCI\_PROTCTL[2]). The internal slave select signal is active high and the CTLOINV (USCI\_LINECTL[7]) can be used for the inversion of the slave select signal.

In SPI Master mode, if the value of SUSPITV (USCI\_PROTCTL[11:8]) is less than 3 and the AUTOSS (USCI\_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.25-12 Auto Slave Select ( $\text{SUSPITV} \geq 0x3$ )



Figure 6.25-13 Auto Slave Select (SUSPITV &lt; 0x3)

#### 6.25.5.8 Slave 3-wire Mode

When the SLV3WIRE (USCI\_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 (USCI\_PROTCTL[1]) only takes effect in SPI Slave mode. Only three pins, SPI\_CLK (through USCIx\_CLK line), SPI\_MOSI (through USCIx\_DAT0 line), and SPI\_MISO (through USCIx\_DAT1 line), are required to communicate with a SPI Master. When the SLV3WIRE (USCI\_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(USCI\_CTL [2:0]) to 0x1.

#### 6.25.5.9 Data Transfer Mode

The USCI controller supports full-duplex SPI transfer and one data channel half-duplex SPI transfer.

- Full-duplex SPI transfer

In full-duplex SPI transfer, there are two data pins. One is used for transmitting data and the other is used for receiving data. Thus, data transmission and data reception can be performed simultaneously.

SCLKMODE (USCI\_PROTCTL[7:6]) defines the transition timing of the data shift output signal on USCIx\_DAT0 pin. The transition may happen at the corresponding edge of SPI bus clock or active edge of slave select signal. The level of the last data bit of a data word is held on USCIx\_DAT0 pin until the next data word begins with the next corresponding edge of the serial bus clock.

- One data channel half-duplex SPI transfer

In one data channel half-duplex SPI transfer, there is only one data pin for data transfer. Thus, the data transmission and data reception are at different time interval. The data shift direction is determined by PORTDIR (USCI\_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.25-14 shows the one output data channel and one input data channel half-duplex transfer diagrams with the external device.



Figure 6.25-14 One Output Data Channel Half-duplex (SPI Master Mode)



Figure 6.25-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] (USCI\_PROTCTL[14:12]) and PORTDIR (USCI\_TXDAT[16]) settings. When TSMSEL (USCI\_PROTCTL[14:12]) is set to 0x4, one data channel half-duplex transfer mode is selected. The PORTDIR (USCI\_TXDAT[16]) is used to define the direction of the corresponding transmit data. When the PORTDIR bit is set to 0, the USCI controller will send the corresponding data to external SPI device. When the PORTDIR bit is set to 1, the controller will read the corresponding data from the external SPI device.

For example, in one data channel half-duplex transfer mode with PORTDIR=0, USCI SPI transmits data through USCIx\_DAT0 pin; if PORTDIR=1, USCI SPI receives data through USCIx\_DAT0 pin.

#### 6.25.5.10 Interrupt

##### Data Transfer Interrupts

- Transmit start interrupt

The interrupt event TXSTIF (USCI\_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 (USCI\_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 (USCI\_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 (USCI\_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 (USCI\_PROTSTS[9]) and SSINAIF (USCI\_PROTSTS[8]), will be set to 1 when SLAVE (USCI\_PROTCTL [0]) is set to 1 and Slave senses the slave select signal active or inactive. The SPI controller will issue an interrupt if SSINAIF (USCI\_PROTIEN[0]) or SSACTIEN (USCI\_PROTIEN[1]), are set to 1. Because the internal slave select signal in SPI function is active high, the ININV (USCI\_CTLIN0[2]) can be used for inverting the slave select signal comes from an active low device.

- Slave time-out interrupt

In SPI Slave mode, there is Slave time-out function for user to know that there is no serial clock input during the period of one word transaction. The Slave time-out function uses the timing measurement counter for the calculation of Slave time-out period which is defined by SLVTOCNT (USCI\_PROTCTL[25:16]). TMCNTSRC (USCI\_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 (USCI\_BRGEN[4]) and the setting value of SLVTOCNT (USCI\_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 (USCI\_PROTCTL[25:16]) before one word transaction is done, the Slave time-out interrupt event occurs and the SLVTOIF (USCI\_PROTSTS[5]) will be set to 1.

#### Buffer-Related Interrupts

The buffer-related interrupts are available if there is transmit/receive buffer in USCI controller.

- Receive buffer overrun interrupt

If there is receive buffer overrun event, RXOVIF (USCI\_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 (USCI\_BUFSTS[11]) will be set as 1. It can be cleared by write 1 into it.

#### 6.25.5.11 Timing Diagram

The slave select signal of USCI SPI protocol is active high by default, and it can be inverted by CTLOINV (USCI\_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 (USCI\_PROTCTL[7:6]). The bit length of a transaction word data is determined by DWIDTH (USCI\_LINECTL[11:8]), and data bit transfer sequence is determined by LSB (USCI\_LINECTL[0]). Four SPI timing diagrams for Master/Slave operations and the related settings are shown below.



Figure 6.25-16 SPI Timing in Master Mode



Figure 6.25-17 SPI Timing in Master Mode (Alternate Phase of Serial Bus Clock)



Figure 6.25-18 SPI Timing in Slave Mode



Figure 6.25-19 SPI Timing in Slave Mode (Alternate Phase of Serial Bus Clock)

#### 6.25.5.12 Programming Flow

This section describes the programming flow for USCI SPI data transfer.

##### For Master mode:

1. Enable USCI peripheral clock by setting CLK\_APBCLK1 register.
2. Configure user-specified pins as USCI function pins by setting corresponding multiple function control registers.
3. Set FUNMODE (USCI\_CTL[2:0]) to 1 to select SPI mode.

4. Set USCI\_BRGEN register to determine the SPI bus clock frequency.
5. According to the requirements of user's application, configure the settings as follows.
  - CTLOINV (USCI\_LINECTL[7]): If the slave selection signal is active low, set this bit to 1; otherwise, set it to 0.
  - DWIDTH (USCI\_LINECTL[11:8]): Data width setting.
  - LSB (USCI\_LINECTL[0]): LSB first or MSB first.
  - TSMSEL (USCI\_PROTCTL[14:12]): Full-duplex SPI transfer or one channel half-duplex SPI transfer.
  - SCLKMODE (USCI\_PROTCTL[7:6]): Determine the clock timing.
  - AUTOSS (USCI\_PROTCTL[3]): Enable automatic slave select function or not.
  - SLAVE (USCI\_PROTCTL[0]): Set to 0 for Master mode.
  - Set PROTEN (USCI\_PROTCTL[31]) to 1 to enable SPI protocol.
6. If automatic slave select function is disabled (AUTOSS=0), set SS (USCI\_PROTCTL[2]) to 1 before data transfer; set SS to 0 to deactivate the slave selection signal by user's application.
7. Write USCI\_TXDAT register to trigger SPI transfer. In half-duplex SPI transfer, the data pin direction is determined by PORTDIR (USCI\_TXDAT[16]) setting.
8. User can get the received data by reading USCI\_RXDAT register as long as RXEMPTY (USCI\_BUFSTS[0]) is 0. The SPI data transfer can be triggered by writing USCI\_TXDAT register as long as TXFULL (USCI\_BUFSTS[9]) is 0.

#### For Slave mode:

1. Enable USCI peripheral clock by setting CLK\_APBCLK1 register.
2. Configure user-specified pins as USCI function pins by setting corresponding multiple function control registers.
3. Set FUNMODE (USCI\_CTL[2:0]) to 1 to select SPI mode.
4. According to the requirements of user's application, configure the settings as follows.
  - ININV (USCI\_CTLIN0[2]): If the slave selection signal is active low, set this bit to 1; otherwise, set it to 0.
  - DWIDTH (USCI\_LINECTL[11:8]): Data width setting.
  - LSB (USCI\_LINECTL[0]): LSB first or MSB first.
  - TSMSEL (USCI\_PROTCTL[14:12]): Full-duplex SPI transfer or one channel half-duplex SPI transfer.
  - SCLKMODE (USCI\_PROTCTL[7:6]): Determine the clock timing.
  - SLAVE (USCI\_PROTCTL[0]): Set to 1 for Slave mode.
5. Set PROTEN (USCI\_PROTCTL[31]) to 1 to enable SPI protocol.
6. Write USCI\_TXDAT register for transmission. In half-duplex SPI transfer, the data pin direction is determined by PORTDIR (USCI\_TXDAT[16]) setting.
7. User can get the received data by reading USCI\_RXDAT register as long as RXEMPTY (USCI\_BUFSTS[0]) is 0. The next datum for transmission can be written to USCI\_TXDAT register as long as TXFULL (USCI\_BUFSTS[9]) is 0.

##### 6.25.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.25.6 Register Map

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

| Register                                                | Offset                     | R/W | Description                                        | Reset Value |
|---------------------------------------------------------|----------------------------|-----|----------------------------------------------------|-------------|
| <b>USCI Base Address:</b>                               |                            |     |                                                    |             |
| <b>USCI<sub>n</sub>_BA = 0x400D_0000 + (0x1000 * n)</b> |                            |     |                                                    |             |
| n= 0, 1                                                 |                            |     |                                                    |             |
| <b>USCI_CTL</b>                                         | USCI <sub>n</sub> _BA+0x00 | R/W | USCI Control Register                              | 0x0000_0000 |
| <b>USCI_INTEN</b>                                       | USCI <sub>n</sub> _BA+0x04 | R/W | USCI Interrupt Enable Register                     | 0x0000_0000 |
| <b>USCI_BRGEN</b>                                       | USCI <sub>n</sub> _BA+0x08 | R/W | USCI Baud Rate Generator Register                  | 0x0000_3C00 |
| <b>USCI_DATINO</b>                                      | USCI <sub>n</sub> _BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0    | 0x0000_0000 |
| <b>USCI_CTLINO</b>                                      | USCI <sub>n</sub> _BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 0x0000_0000 |
| <b>USCI_CLKIN</b>                                       | USCI <sub>n</sub> _BA+0x28 | R/W | USCI Input Clock Signal Configuration Register     | 0x0000_0000 |
| <b>USCI_LINECTL</b>                                     | USCI <sub>n</sub> _BA+0x2C | R/W | USCI Line Control Register                         | 0x0000_0000 |
| <b>USCI_TXDAT</b>                                       | USCI <sub>n</sub> _BA+0x30 | W   | USCI Transmit Data Register                        | 0x0000_0000 |
| <b>USCI_RXDAT</b>                                       | USCI <sub>n</sub> _BA+0x34 | R   | USCI Receive Data Register                         | 0x0000_0000 |
| <b>USCI_BUFCTL</b>                                      | USCI <sub>n</sub> _BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register      | 0x0000_0000 |
| <b>USCI_BUFSTS</b>                                      | USCI <sub>n</sub> _BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register       | 0x0000_0101 |
| <b>USCI_PDMACTL</b>                                     | USCI <sub>n</sub> _BA+0x40 | R/W | USCI PDMA Control Register                         | 0x0000_0000 |
| <b>USCI_WKCTL</b>                                       | USCI <sub>n</sub> _BA+0x54 | R/W | USCI Wake-up Control Register                      | 0x0000_0000 |
| <b>USCI_WKSTS</b>                                       | USCI <sub>n</sub> _BA+0x58 | R/W | USCI Wake-up Status Register                       | 0x0000_0000 |
| <b>USCI_PROTCTL</b>                                     | USCI <sub>n</sub> _BA+0x5C | R/W | USCI Protocol Control Register                     | 0x0000_0300 |
| <b>USCI_PROTIEN</b>                                     | USCI <sub>n</sub> _BA+0x60 | R/W | USCI Protocol Interrupt Enable Register            | 0x0000_0000 |
| <b>USCI_PROTSTS</b>                                     | USCI <sub>n</sub> _BA+0x64 | R/W | USCI Protocol Status Register                      | 0x0000_0000 |

### 6.25.7 Register Description

#### USCI Control Register (USCI\_CTL)

| Register | Offset         | R/W | Description           |  |  |  |  | Reset Value |
|----------|----------------|-----|-----------------------|--|--|--|--|-------------|
| USCI_CTL | USCIIn_BA+0x00 | R/W | USCI Control Register |  |  |  |  | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [2:0]  | FUNMODE     | <p><b>Function Mode</b></p> <p>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.</p> <p>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<sup>2</sup>C protocol is selected.</p> <p><b>Note:</b> Other bit combinations are reserved.</p> |

USCI Interrupt Enable Register (USCI\_INTEN)

| Register   | Offset         | R/W | Description                    |  |  |  | Reset Value |
|------------|----------------|-----|--------------------------------|--|--|--|-------------|
| USCI_INTEN | USCIIn_BA+0x04 | R/W | USCI Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                         |
| [4]    | RXENDIEN    | <p><b>Receive End Interrupt Enable Bit</b><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.</p>           |
| [3]    | RXSTIEN     | <p><b>Receive Start Interrupt Enable Bit</b><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.</p>      |
| [2]    | TXENDIEN    | <p><b>Transmit End Interrupt Enable Bit</b><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.</p> |
| [1]    | TXSTIEN     | <p><b>Transmit Start Interrupt Enable Bit</b><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.</p>  |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                         |

USCI Baud Rate Generator Register (USCI\_BRGEN)

| Register   | Offset         | R/W | Description                       |  |  |  |  | Reset Value |
|------------|----------------|-----|-----------------------------------|--|--|--|--|-------------|
| USCI_BRGEN | USCIIn_BA+0x08 | R/W | USCI Baud Rate Generator Register |  |  |  |  | 0x0000_3C00 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [25:16] | CLKDIV      | <p><b>Clock Divider</b><br/> This bit field defines the ratio between the protocol clock frequency <math>f_{PROT\_CLK}</math> and the clock divider frequency <math>f_{DIV\_CLK}</math> (<math>f_{DIV\_CLK} = f_{PROT\_CLK} / (\text{CLKDIV} + 1)</math> ).</p> <p><b>Note:</b> In UART function, it can be updated by hardware in the 4<sup>th</sup> falling edge of the input data 0x55 when the auto baud rate function (ABREN(USCI_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 (USCI_PROTCTL[24:16]) to calculate the precise baud rate.</p> |
| [15:6]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [5]     | TMCNTSRC    | <p><b>Time Measurement Counter Clock Source Selection</b><br/> 0 = Time measurement counter with <math>f_{PROT\_CLK}</math>.<br/> 1 = Time measurement counter with <math>f_{DIV\_CLK}</math>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [4]     | TMCNTEN     | <p><b>Time Measurement Counter Enable Bit</b><br/> This bit enables the 10-bit timing measurement counter.<br/> 0 = Time measurement counter Disabled.<br/> 1 = Time measurement counter Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [3:2]   | SPCLKSEL    | <p><b>Sample Clock Source Selection</b><br/> This bit field used for the clock source selection of sample clock (<math>f_{SAMP\_CLK}</math>) for the protocol processor.</p> <p>00 = <math>f_{DIV\_CLK}</math>.<br/> 01 = <math>f_{PROT\_CLK}</math>.<br/> 10 = <math>f_{SCLK}</math>.<br/> 11 = <math>f_{REF\_CLK}</math>.</p>                                                                                                                                                                                                                                                                                                                   |
| [1]     | PTCLKSEL    | <p><b>Protocol Clock Source Selection</b><br/> This bit selects the source of protocol clock (<math>f_{PROT\_CLK}</math>).<br/> 0 = Reference clock <math>f_{REF\_CLK}</math>.<br/> 1 = <math>f_{REF\_CLK2}</math> (its frequency is half of <math>f_{REF\_CLK}</math>).</p>                                                                                                                                                                                                                                                                                                                                                                      |

|     |         |                                                                                                                                                                            |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | RCLKSEL | <b>Reference Clock Source Selection</b><br>This bit selects the source of reference clock ( $f_{REF\_CLK}$ ).<br>0 = Peripheral device clock $f_{PCLK}$ .<br>1 = Reserved. |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**USCI Input Data Signal Configuration (USCI\_DATIN0)**

| Register           | Offset         | R/W | Description                                     |  |  |  | Reset Value |
|--------------------|----------------|-----|-------------------------------------------------|--|--|--|-------------|
| <b>USCI_DATIN0</b> | USCIIn_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0 |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [2]    | <b>ININV</b>    | <p><b>Input Signal Inverse Selection</b></p> <p>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.</p> <p><b>Note:</b> In SPI protocol, it is suggested this bit should be set as 0.</p>                                                                                                                                                            |
| [1]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]    | <b>SYNCSEL</b>  | <p><b>Input Signal Synchronization Selection</b></p> <p>This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.<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.</p> <p><b>Note:</b> In SPI protocol, it is suggested this bit should be set as 0.</p> |

USCI Input Control Signal Configuration (USCI\_CTLIN0)

| Register    | Offset         | R/W | Description                                        |  |  |  | Reset Value |
|-------------|----------------|-----|----------------------------------------------------|--|--|--|-------------|
| USCI_CTLIN0 | USCIIn_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [2]    | <b>ININV</b>    | <p><b>Input Signal Inverse Selection</b></p> <p>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.</p>                                                                                                                                                                                                                                              |
| [1]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]    | <b>SYNCSEL</b>  | <p><b>Input Synchronization Signal Selection</b></p> <p>This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.<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.</p> <p><b>Note:</b> In SPI protocol, it is suggested this bit should be set as 0.</p> |

USCI Input Clock Signal Configuration (USCI\_CLKIN)

| Register   | Offset         | R/W | Description                                    |  |  |  |  | Reset Value |
|------------|----------------|-----|------------------------------------------------|--|--|--|--|-------------|
| USCI_CLKIN | USCIIn_BA+0x28 | R/W | USCI Input Clock Signal Configuration Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [0]    | SYNCSEL     | <p><b>Input Synchronization Signal Selection</b></p> <p>This bit selects if the un-synchronized input signal or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.</p> <p>0 = The un-synchronized signal can be taken as input for the data shift unit.</p> <p>1 = The synchronized signal can be taken as input for the data shift unit.</p> <p><b>Note:</b> In SPI protocol, it is suggested this bit should be set as 0.</p> |

USCI Line Control Register (USCI\_LINECTL)

| Register     | Offset         | R/W | Description                |  |  |  | Reset Value |
|--------------|----------------|-----|----------------------------|--|--|--|-------------|
| USCI_LINECTL | USCIIn_BA+0x2C | R/W | USCI Line Control Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [11:8]  | DWIDTH      | <p><b>Word Length of Transmission</b></p> <p>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.</p> <p>0x0: The data word contains 16 bits located at bit positions [15:0].</p> <p>0x1: Reserved.</p> <p>0x2: Reserved.</p> <p>0x3: Reserved.</p> <p>0x4: The data word contains 4 bits located at bit positions [3:0].</p> <p>0x5: The data word contains 5 bits located at bit positions [4:0].</p> <p>...</p> <p>0xF: The data word contains 15 bits located at bit positions [14:0].</p> |
| [7]     | CTLOINV     | <p><b>Control Signal Output Inverse Selection</b></p> <p>This bit defines the relation between the internal control signal and the output control signal.</p> <p>0 = No effect.</p> <p>1 = The control signal will be inverted before its output.</p> <p><b>Note:</b> The control signal has different definitions in different protocol. In SPI protocol, the control signal means slave select signal.</p>                                                                                                                                                                                                                                 |
| [6]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [5]     | DATOINV     | <p><b>Data Output Inverse Selection</b></p> <p>This bit defines the relation between the internal shift data value and the output data signal of USCIx_DAT0/1 pin.</p> <p>0 = Data output level is not inverted.</p> <p>1 = Data output level is inverted.</p>                                                                                                                                                                                                                                                                                                                                                                               |
| [4:1]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [0]     | LSB         | LSB First Transmission Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

|  |  |                                                                                                                         |
|--|--|-------------------------------------------------------------------------------------------------------------------------|
|  |  | 0 = The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is transmitted/received first. |
|--|--|-------------------------------------------------------------------------------------------------------------------------|

|  |  |                                                                            |
|--|--|----------------------------------------------------------------------------|
|  |  | 1 = The LSB, the bit 0 of data buffer, will be transmitted/received first. |
|--|--|----------------------------------------------------------------------------|

**USCI Transmit Data Register (USCI\_TXDAT)**

| Register   | Offset         | R/W | Description                 |  |  |  | Reset Value |
|------------|----------------|-----|-----------------------------|--|--|--|-------------|
| USCI_TXDAT | USCIIn_BA+0x30 | W   | USCI Transmit Data Register |  |  |  | 0x0000_0000 |



| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [16]    | <b>PORTDIR</b>  | <p><b>Port Direction Control</b></p> <p>This bit field is only available while USCI operates in SPI protocol (FUNMODE = 0x1) with half-duplex transfer. It is used to define the direction of the data port pin. When software writes USCI_TXDAT register, the transmit data and its port direction are settled simultaneously.</p> <p>0 = The data pin is configured as output mode.<br/>1 = The data pin is configured as input mode.</p> |
| [15:0]  | <b>TXDAT</b>    | <p><b>Transmit Data</b></p> <p>Software can use this bit field to write 16-bit transmit data for transmission. In order to avoid overwriting the transmit data, user have to check TXEMPTY (USCI_BUFSTS[8]) status before writing transmit data into this bit field.</p>                                                                                                                                                                    |

**USCI Receive Data Register (USCI\_RXDAT)**

| Register   | Offset         | R/W | Description                |  |  |  | Reset Value |
|------------|----------------|-----|----------------------------|--|--|--|-------------|
| USCI_RXDAT | USCIIn_BA+0x34 | R   | USCI Receive Data Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                        |
|---------|-------------|--------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                              |
| [15:0]  | RXDAT       | <b>Received Data</b><br>This bit field monitors the received data which stored in receive data buffer. |

**USCI Transmitter/Receive Buffer Control Register (USCI\_BUFCTL)**

| Register    | Offset         | R/W | Description                                   |  |  |  |  | Reset Value |
|-------------|----------------|-----|-----------------------------------------------|--|--|--|--|-------------|
| USCI_BUFCTL | USCIIn_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                        |
| [17]    | RXRST       | <b>Receive Reset</b><br>0 = No effect.<br>1 = Reset the receive-related counters, state machine, and the content of receive shift register and data buffer.<br><b>Note:</b> It is cleared automatically after one PCLK cycle.                                                                                                    |
| [16]    | TXRST       | <b>Transmit Reset</b><br>0 = No effect.<br>1 = Reset the transmit-related counters, state machine, and the content of transmit shift register and data buffer.<br><b>Note1:</b> It is cleared automatically after one PCLK cycle.<br><b>Note2:</b> Write 1 to this bit will set the output data pin to zero if USCI_BUFCTL[5]=0. |
| [15]    | RXCLR       | <b>Clear Receive Buffer</b><br>0 = No effect.<br>1 = The receive buffer is cleared. Should only be used while the buffer is not taking part in data traffic.<br><b>Note:</b> It is cleared automatically after one PCLK cycle.                                                                                                   |
| [14]    | RXOVIEN     | <b>Receive Buffer Overrun Interrupt Enable Bit</b><br>0 = Receive overrun interrupt Disabled.<br>1 = Receive overrun interrupt Enabled.                                                                                                                                                                                          |
| [13:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                        |
| [7]     | TXCLR       | <b>Clear Transmit Buffer</b><br>0 = No effect.<br>1 = The transmit buffer is cleared. Should only be used while the buffer is not taking part in data traffic.<br><b>Note:</b> It is cleared automatically after one PCLK cycle.                                                                                                 |
| [6]     | TXUDRIEN    | <b>Slave Transmit Under Run Interrupt Enable Bit</b>                                                                                                                                                                                                                                                                             |

|       |                 |                                                                                         |
|-------|-----------------|-----------------------------------------------------------------------------------------|
|       |                 | 0 = Transmit under-run interrupt Disabled.<br>1 = Transmit under-run interrupt Enabled. |
| [5:0] | <b>Reserved</b> | Reserved.                                                                               |

**USCI Transmit/Receive Buffer Status Register (USCI\_BUFSTS)**

| Register    | Offset         | R/W | Description                                  |  |  |  | Reset Value |
|-------------|----------------|-----|----------------------------------------------|--|--|--|-------------|
| USCI_BUFSTS | USCIIn_BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register |  |  |  | 0x0000_0101 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [11]    | <b>TXUDRIF</b>  | <p><b>Transmit Buffer Under-run Interrupt Status</b></p> <p>This bit indicates that a transmit buffer under-run event has been detected. If enabled by TXUDRIEN (USCI_BUFCCTL[6]), the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit</p> <p>0 = A transmit buffer under-run event has not been detected.<br/>1 = A transmit buffer under-run event has been detected.</p> |
| [10]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [9]     | <b>TXFULL</b>   | <p><b>Transmit Buffer Full Indicator</b></p> <p>0 = Transmit buffer is not full.<br/>1 = Transmit buffer is full.</p>                                                                                                                                                                                                                                                                                                    |
| [8]     | <b>TXEMPTY</b>  | <p><b>Transmit Buffer Empty Indicator</b></p> <p>0 = Transmit buffer is not empty.<br/>1 = Transmit buffer is empty and available for the next transmission datum.</p>                                                                                                                                                                                                                                                   |
| [7:4]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [3]     | <b>RXOVIF</b>   | <p><b>Receive Buffer Over-run Interrupt Status</b></p> <p>This bit indicates that a receive buffer overrun event has been detected. If RXOVIEN (USCI_BUFCCTL[14]) is enabled, the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit.</p> <p>0 = A receive buffer overrun event has not been detected.<br/>1 = A receive buffer overrun event has been detected.</p>           |
| [2]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [1]     | <b>RXFULL</b>   | <p><b>Receive Buffer Full Indicator</b></p> <p>0 = Receive buffer is not full.<br/>1 = Receive buffer is full.</p>                                                                                                                                                                                                                                                                                                       |
| [0]     | <b>RXEMPTY</b>  | <b>Receive Buffer Empty Indicator</b>                                                                                                                                                                                                                                                                                                                                                                                    |

|  |  |                                                                  |
|--|--|------------------------------------------------------------------|
|  |  | 0 = Receive buffer is not empty.<br>1 = Receive buffer is empty. |
|--|--|------------------------------------------------------------------|

**USCI PDMA Control Register (USCI\_PDMACTL)**

| Register     | Offset         | R/W | Description                |  |  |  | Reset Value |
|--------------|----------------|-----|----------------------------|--|--|--|-------------|
| USCI_PDMACTL | USCIIn_BA+0x40 | R/W | USCI 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 |    |    |    | PDMAEN | RXPDMAEN | TXPDMAEN | PDMARST |

| Bits   | Description     |                                                                                                                                                           |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | <b>Reserved</b> | Reserved.                                                                                                                                                 |
| [3]    | <b>PDMAEN</b>   | <b>PDMA Mode Enable Bit</b><br>0 = PDMA function Disabled.<br>1 = PDMA function Enabled.<br>Notice: The I <sup>2</sup> C is not supporting PDMA function. |
| [2]    | <b>RXPDMAEN</b> | <b>PDMA Receive Channel Available</b><br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.                                        |
| [1]    | <b>TXPDMAEN</b> | <b>PDMA Transmit Channel Available</b><br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled.                                     |
| [0]    | <b>PDMARST</b>  | <b>PDMA Reset</b><br>0 = No effect.<br>1 = Reset the USCI's PDMA control logic. This bit will be cleared to 0 automatically.                              |

**USCI Wake-up Control Register (USCI\_WKCTL)**

| Register   | Offset         | R/W | Description                   |  |  |  | Reset Value |
|------------|----------------|-----|-------------------------------|--|--|--|-------------|
| USCI_WKCTL | USCIIn_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 |    |    |    |    | PDBOPT | WKADDREN | WKEN |

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [2]    | <b>PDBOPT</b>   | <p><b>Power Down Blocking Option</b><br/>           0 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, MCU will stop the transfer and enter Power-down mode immediately.<br/>           1 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, the on-going transfer will not be stopped and MCU will enter idle mode immediately.</p> |
| [1]    | <b>WKADDREN</b> | <p><b>Wake-up Address Match Enable Bit</b><br/>           0 = The chip is woken up according data toggle.<br/>           1 = The chip is woken up according address match.</p>                                                                                                                                                                                                                                                           |
| [0]    | <b>WKEN</b>     | <p><b>Wake-up Enable Bit</b><br/>           0 = Wake-up function Disabled.<br/>           1 = Wake-up function Enabled.</p>                                                                                                                                                                                                                                                                                                              |

USCI Wake-up Status Register (USCI\_WKSTS)

| Register   | Offset         | R/W | Description                  |  |  |  | Reset Value |
|------------|----------------|-----|------------------------------|--|--|--|-------------|
| USCI_WKSTS | USCIIn_BA+0x58 | R/W | USCI Wake-up Status Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | 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 – USCI PROTCTL (SPI)

| Register     | Offset                     | R/W | Description                    |  |  |  | Reset Value |
|--------------|----------------------------|-----|--------------------------------|--|--|--|-------------|
| USCI_PROTCTL | USCI <sub>n</sub> _BA+0x5C | R/W | USCI Protocol Control Register |  |  |  | 0x0000_0300 |

|          |          |          |          |          |    |          |       |
|----------|----------|----------|----------|----------|----|----------|-------|
| 31       | 30       | 29       | 28       | 27       | 26 | 25       | 24    |
| PROTEN   | Reserved |          | TXUDRPOL | Reserved |    | SLVTOCNT |       |
| 23       | 22       | 21       | 20       | 19       | 18 | 17       | 16    |
| SLVTOCNT |          |          |          |          |    |          |       |
| 15       | 14       | 13       | 12       | 11       | 10 | 9        | 8     |
| Reserved | TSMSEL   |          |          | SUSPITV  |    |          |       |
| 7        | 6        | 5        | 4        | 3        | 2  | 1        | 0     |
| SCLKMODE |          | Reserved |          | AUTOSS   | SS | SLV3WIRE | SLAVE |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | PROTEN      | <b>SPI Protocol Enable Bit</b><br>0 = SPI Protocol Disabled.<br>1 = SPI Protocol Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [30:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [28]    | TXUDRPOL    | <b>Transmit Under-run Data Polarity (for Slave)</b><br>This bit defines the transmitting data level 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    | <b>Slave Mode Time-out Period (Slave Only)</b><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, USCI_BRGEN[5]) between the two edges of input SCLK will assert the Slave time-out event. Writing 0x0 into this bit field will disable the Slave time-out function.<br>Example: Assume SLVTOCNT is 0x0A and TMCNTSRC (USCI_BRGEN[5]) is 1, it means the time-out event will occur if the state of SPI bus clock pin is not changed more than (10+1) periods of $f_{DIV\_CLK}$ . |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [14:12] | TSMSEL      | <b>Transmit Data Mode Selection</b><br>This bit field describes how receive and transmit data is shifted in and out.<br>TSMSEL = 000b: Full-duplex SPI.<br>TSMSEL = 100b: Half-duplex SPI.<br>Other values are reserved.<br><b>Note:</b> Changing the value of this bit field will produce the TXRST and RXRST to clear the TX/RX data buffer automatically.                                                                                                                                                                                                             |
| [11:8]  | SUSPITV     | <b>Suspend Interval (Master Only)</b><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 interval between the last clock edge of the preceding transaction word and the first clock                                                                                                                                                                                                                                                           |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | edge of the following transaction word. The default value is 0x3. The period of the suspend interval is obtained according to the following equation.<br>$(\text{SUSPITV}[3:0] + 0.5) * \text{period of SPI\_CLK clock cycle}$<br>Example:<br>SUSPITV = 0x0 ... 0.5 SPI_CLK clock cycle.<br>SUSPITV = 0x1 ... 1.5 SPI_CLK clock cycle.<br>.....<br>SUSPITV = 0xE ... 14.5 SPI_CLK clock cycle.<br>SUSPITV = 0xF ... 15.5 SPI_CLK clock cycle.                                                                                                                                                                                |
| [7:6] | <b>SCLKMODE</b> | <b>Serial Bus Clock Mode</b><br>This bit field defines the SCLK idle status, data transmit, and data receive edge.<br>MODE0 = The idle state of SPI clock is low level. Data is transmitted with falling edge and received with rising edge.<br>MODE1 = The idle state of SPI clock is low level. Data is transmitted with rising edge and received with falling edge.<br>MODE2 = The idle state of SPI clock is high level. Data is transmitted with rising edge and received with falling edge.<br>MODE3 = The idle state of SPI clock is high level. Data is transmitted with falling edge and received with rising edge. |
| [5:4] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [3]   | <b>AUTOSS</b>   | <b>Automatic Slave Select Function Enable (Master Only)</b><br>0 = Slave select signal will be controlled by the setting value of SS (USCI_PROTCTL[2]) bit.<br>1 = Slave select signal will be generated automatically. The slave select signal will be asserted by the SPI controller when transmit/receive is started, and will be de-asserted after each transmit/receive is finished.                                                                                                                                                                                                                                    |
| [2]   | <b>SS</b>       | <b>Slave Select Control (Master Only)</b><br>If AUTOSS bit is cleared, setting this bit to 1 will set the slave select signal to active state, and setting this bit to 0 will set the slave select back to inactive state.<br>If the AUTOSS function is enabled (AUTOSS = 1), the setting value of this bit will not affect the current state of slave select signal.<br><b>Note:</b> In SPI protocol, the internal slave select signal is active high.                                                                                                                                                                      |
| [1]   | <b>SLV3WIRE</b> | <b>Slave 3-wire Mode Selection (Slave Only)</b><br>The SPI protocol can work with 3-wire interface (without slave select signal) in Slave mode.<br>0 = 4-wire bi-direction interface.<br>1 = 3-wire bi-direction interface.                                                                                                                                                                                                                                                                                                                                                                                                  |
| [0]   | <b>SLAVE</b>    | <b>Slave Mode Selection</b><br>0 = Master mode.<br>1 = Slave mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**USCI Protocol Interrupt Enable Register – USCI\_PROTIEN (SPI)**

| Register     | Offset         | R/W | Description                             |  |  |  | Reset Value |
|--------------|----------------|-----|-----------------------------------------|--|--|--|-------------|
| USCI_PROTIEN | USCIIn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [3]    | <b>SLVBEIEN</b> | <p><b>Slave Mode Bit Count Error Interrupt Enable Bit</b></p> <p>If data transfer is terminated by slave time-out or slave select inactive event in Slave mode, so that the transmit/receive data bit count does not match the setting of DWIDTH (USCI_LINECTL[11:8]). Bit count error event occurs.</p> <p>0 = The Slave mode bit count error interrupt Disabled.<br/>1 = The Slave mode bit count error interrupt Enabled.</p> |
| [2]    | <b>SLVTOIEN</b> | <p><b>Slave Time-out Interrupt Enable Bit</b></p> <p>In SPI protocol, this bit enables the interrupt generation in case of a Slave time-out event.</p> <p>0 = The Slave time-out interrupt Disabled.<br/>1 = The Slave time-out interrupt Enabled.</p>                                                                                                                                                                           |
| [1]    | <b>SSACTIEN</b> | <p><b>Slave Select Active Interrupt Enable Bit</b></p> <p>This bit enables/disables the generation of a slave select interrupt if the slave select changes to active.</p> <p>0 = Slave select active interrupt generation Disabled.<br/>1 = Slave select active interrupt generation Enabled.</p>                                                                                                                                |
| [0]    | <b>SSINAIEN</b> | <p><b>Slave Select Inactive Interrupt Enable Bit</b></p> <p>This bit enables/disables the generation of a slave select interrupt if the slave select changes to inactive.</p> <p>0 = Slave select inactive interrupt generation Disabled.<br/>1 = Slave select inactive interrupt generation Enabled.</p>                                                                                                                        |

**USCI Protocol Status Register – USCI\_PROTSTS (SPI)**

| Register     | Offset         | R/W | Description                   |  |  |  | Reset Value |
|--------------|----------------|-----|-------------------------------|--|--|--|-------------|
| USCI_PROTSTS | USCIIn_BA+0x64 | R/W | USCI Protocol Status Register |  |  |  | 0x0000_0000 |

|          |         |         |         |        |         |         |          |
|----------|---------|---------|---------|--------|---------|---------|----------|
| 31       | 30      | 29      | 28      | 27     | 26      | 25      | 24       |
| Reserved |         |         |         |        |         |         |          |
| 23       | 22      | 21      | 20      | 19     | 18      | 17      | 16       |
| Reserved |         |         |         |        | SLVUDR  | BUSY    | SSLINE   |
| 15       | 14      | 13      | 12      | 11     | 10      | 9       | 8        |
| Reserved |         |         |         |        | SSACTIF | SSINAIF |          |
| 7        | 6       | 5       | 4       | 3      | 2       | 1       | 0        |
| Reserved | SLVBEIF | SLVTOIF | RXENDIF | RXSTIF | TXENDIF | TXSTIF  | Reserved |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [18]    | SLVUDR      | <p><b>Slave Mode Transmit Under-run Status (Read Only)</b></p> <p>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 (USCI_PROTCTL[28]) or not.</p> <p>0 = Slave transmit under run event does not occur.<br/>1 = Slave transmit under run event occurs.</p>                                                                                                                                                                                              |
| [17]    | BUSY        | <p><b>Busy Status (Read Only)</b></p> <p>0 = SPI is in idle state.<br/>1 = SPI is in busy state.</p> <p>The following listing are the bus busy conditions:</p> <ul style="list-style-type: none"> <li>a. USCI_PROTCTL[31] = 1 and the TXEMPTY = 0.</li> <li>b. For SPI Master mode, the TXEMPTY = 1 but the current transaction is not finished yet.</li> <li>c. For SPI Slave mode, the USCI_PROTCTL[31] = 1 and there is serial clock input into the SPI core logic when slave select is active.</li> <li>d. For SPI Slave mode, the USCI_PROTCTL[31] = 1 and the transmit buffer or transmit shift register is not empty even if the slave select is inactive.</li> </ul> |
| [16]    | SSLINE      | <p><b>Slave Select Line Bus Status (Read Only)</b></p> <p>This bit is only available in Slave mode. It used to monitor the current status of the input slave select signal on the bus.</p> <p>0 = The slave select line status is 0.<br/>1 = The slave select line status is 1.</p>                                                                                                                                                                                                                                                                                                                                                                                          |
| [15:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [9]     | SSACTIF     | <p><b>Slave Select Active Interrupt Flag (for Slave Only)</b></p> <p>This bit indicates that the internal slave select signal has changed to active. It is cleared by software writes one to this bit</p> <p>0 = The slave select signal has not changed to active.</p>                                                                                                                                                                                                                                                                                                                                                                                                      |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | 1 = The slave select signal has changed to active.<br><b>Note:</b> The internal slave select signal is active high.                                                                                                                                                                                                                                                                   |
| [8] | <b>SSINAIF</b>  | <b>Slave Select Inactive Interrupt Flag (for Slave Only)</b><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><b>Note:</b> The internal slave select signal is active high. |
| [7] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |
| [6] | <b>SLVBEIF</b>  | <b>Slave Bit Count Error Interrupt Flag (for Slave Only)</b><br>0 = Slave bit count error event did not occur.<br>1 = Slave bit count error event occurred.<br><b>Note:</b> It is cleared by software write 1 to this bit.                                                                                                                                                            |
| [5] | <b>SLVTOIF</b>  | <b>Slave Time-out Interrupt Flag (for Slave Only)</b><br>0 = Slave time-out event did not occur.<br>1 = Slave time-out event occurred.<br><b>Note:</b> It is cleared by software write 1 to this bit                                                                                                                                                                                  |
| [4] | <b>RXENDIF</b>  | <b>Receive End Interrupt Flag</b><br>0 = Receive end event did not occur.<br>1 = Receive end event occurred.<br><b>Note:</b> It is cleared by software write 1 to this bit                                                                                                                                                                                                            |
| [3] | <b>RXSTIF</b>   | <b>Receive Start Interrupt Flag</b><br>0 = Receive start event did not occur.<br>1 = Receive start event occurred.<br><b>Note:</b> It is cleared by software write 1 to this bit                                                                                                                                                                                                      |
| [2] | <b>TXENDIF</b>  | <b>Transmit End Interrupt Flag</b><br>0 = Transmit end event did not occur.<br>1 = Transmit end event occurred.<br><b>Note:</b> It is cleared by software write 1 to this bit                                                                                                                                                                                                         |
| [1] | <b>TXSTIF</b>   | <b>Transmit Start Interrupt Flag</b><br>0 = Transmit start event did not occur.<br>1 = Transmit start event occurred.<br><b>Note:</b> It is cleared by software write 1 to this bit                                                                                                                                                                                                   |
| [0] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |

## 6.26 USCI - I<sup>2</sup>C Mode

### 6.26.1 Overview

On I<sup>2</sup>C bus, data is transferred between a Master and a Slave. Data bits transfer on the SCL and SDA lines are synchronously on a byte-by-byte basis. Each data byte is 8-bit. 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.26-1 for more detailed I<sup>2</sup>C BUS Timing.



Figure 6.26-1 I<sup>2</sup>C Bus Timing

The device's on-chip I<sup>2</sup>C provides the serial interface that meets the I<sup>2</sup>C bus standard mode specification. The I<sup>2</sup>C port handles byte transfers autonomously. The I<sup>2</sup>C mode is selected by FUNMODE (USCI\_CTL [2:0]) = 100B. When enable this port, the USCI interfaces to the I<sup>2</sup>C bus via two pins: SDA and SCL. When I/O pins are used as I<sup>2</sup>C ports, user must set the pins function to I<sup>2</sup>C in advance.

**Note:** Pull-up resistor is needed for I<sup>2</sup>C operation because the SDA and SCL are set to open-drain pins when USCI is selected to I<sup>2</sup>C operation mode .

### 6.26.2 Features

- Full master and slave device capability
- Supports of 7-bit addressing, as well as 10-bit addressing
- Communication in standard mode (100 kBit/s) or in fast mode (up to 400 kBit/s)
- Supports multi-master bus
- Supports 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.26.3 Block Diagram



Figure 6.26-2 USCI I<sup>2</sup>C Mode Block Diagram

### 6.26.4 Basic Configuration

#### 6.26.4.1 USCI0 I<sup>2</sup>C Basic Configurations

- Clock Source Configuration
  - Enable USCI0 peripheral clock in USCI0CKEN (CLK\_APBCLK1[8]).
  - Enable USCI0\_I2C function in USCI\_CTL[2:0] register, USCI\_CTL[2:0]=3'b100
- Reset Configuration
  - Reset USCI0 controller in USCI0RST (SYS\_IPRST2[8]).
- Pin Configuration

| Group | Pin Name   | GPIO  | MFP  |
|-------|------------|-------|------|
| USCI0 | USCI0_CLK  | PD.0  | MFP3 |
|       |            | PB.12 | MFP5 |
|       |            | PA.11 | MFP6 |
|       |            | PE.2  | MFP7 |
|       | USCI0_DAT0 | PD.1  | MFP3 |
|       |            | PB.13 | MFP5 |
|       |            | PA.10 | MFP6 |
|       |            | PE.3  | MFP7 |

#### 6.26.4.2 USCI1 I<sup>2</sup>C Basic Configurations

- Clock Source Configuration
  - Enable USCI1 peripheral clock in USCI1CKEN (CLK\_APBCLK1[9]).
  - Enable USCI1\_SPI function in USCI\_CTL[2:0] register, USCI\_CTL[2:0]=3'b100
- Reset Configuration
  - Reset USCI1 controller in USCI1RST (SYS\_IPRST2[9]).
- Pin Configuration

| Group | Pin Name   | GPIO        | MFP  |
|-------|------------|-------------|------|
| USCI1 | USCI1_CLK  | PB.8        | MFP4 |
|       |            | PD.7, PE.12 | MFP6 |
|       |            | PB.1        | MFP8 |
|       | USCI1_DAT0 | PB.7        | MFP4 |
|       |            | PD.5, PE.10 | MFP6 |
|       |            | PB.2        | MFP8 |

#### 6.26.5 Functional Description

##### 6.26.5.1 START or Repeated START Signal

Figure 6.26-3 shows the typical I<sup>2</sup>C protocol. Normally, a standard communication consists of four parts:

- START or Repeated START signal generation
- Slave address and R/W bit transfer
- Data transfer
- STOP signal generation



Figure 6.26-3 I<sup>2</sup>C Protocol

When the bus is free/idle, meaning no master device is engaging the bus (both SCL and SDA lines are high), a master can initiate a transfer by sending a START signal. A START signal, usually referred to as the "S" bit, is defined as a HIGH to LOW transition on the SDA line while SCL is HIGH. The START signal denotes the beginning of a new data transmission.

A Repeated START is 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.26.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.26-4 shows the waveform of START, Repeat START and STOP.



Figure 6.26-4 START and STOP Conditions

### 6.26.5.3 Slave Address Transfer

After a (Repeated) START condition, the master sends a slave address to identify the target device of the communication. The start address can comprise one or two address bytes (for 7-bit or for 10-bit addressing schemes). After an address byte, a slave sensitive to the transmitted address has to acknowledge the reception.

Therefore, the slave's address can be programmed in the device, where it is compared to the received address. In case of a match, the slave answers with an acknowledge (SDA = 0). Slaves that are not targeted answer with a non-acknowledge (SDA = 1). In addition to the match of the programmed address, another address byte value has to be answered with an acknowledge if the slave is capable to handle the corresponding requests. The address byte 00H indicates a general call address that can be acknowledged.

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 (USCI\_PROTCTL [0]) is set the I<sup>2</sup>C port hardware will respond to General Call address (00H). Clear GC bit to disable general call function.
- The I<sup>2</sup>C port is equipped with one device address registers, USCI\_DEVADDRn (n = 0~1). In 7-bit address mode, the first 7 bits of a received first address byte are compared to the programmed slave address (USCI\_DEVADDRn [6:0]). If these bits match, the slave sends an acknowledge.
- For 10 bit addressing mode, if the slave address is programmed to 1111 0XXB, the XX bits are compared to the bits USCI\_DEVADDR [9:8] to check for address match and also sends an acknowledge when ADDR10EN (USCI\_PROTCTL [4]) is set. The slave waits for a second address byte compares it with USCI\_DEVADDR [7:0] and sends an acknowledge accordingly to cover the 10 bit addressing mode. The user has to take care about reserved addresses (refer to I<sup>2</sup>C specification for more detailed description). Only the address 1111 0XXB is supported. Under each of these conditions, bit SLASEL (USCI\_PROTSTS [14]) will be set when the addressing delivered a match. This SLASEL (USCI\_PROTSTS [14]) bit is cleared automatically by a (Repeated) START or STOP condition.
- The I<sup>2</sup>C port is equipped multiple address recognition with one address mask registers I2C\_ADDRMSKn (n = 0~1). When the bit in the address mask register is set to 1, it means the received corresponding address bit is "Don't care". If the bit is set to 0, it means the received corresponding register bit should be exactly the same as address register.

#### 6.26.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.26-5 Bit Transfer on the I<sup>2</sup>C Bus

If the master received data, does Not Acknowledge (NACK) the slave, the slave releases the SDA line for the master to generate a STOP or Repeated START signal.



Figure 6.26-6 Acknowledge on the I<sup>2</sup>C Bus

#### 6.26.5.5 Clock Baud Rate Bits

The data baud rate of I<sup>2</sup>C is determined by USCI\_BRGEN register when I<sup>2</sup>C is in Master Mode, and it is not necessary in a Slave mode. In the Slave mode, I<sup>2</sup>C will automatically synchronize it with any clock frequency from master I<sup>2</sup>C device. The bits RCLKSEL, SPCLKSEL, PDSCNT, and DSCNT define the baud rate setting:

- RCLKSEL (USCI\_BRGEN [0])  
to define the input frequency  $f_{REF\_CLK}$
- SPCLKSEL (USCI\_BRGEN[3:2])  
to define the multiple source of the sample clock  $f_{SAMP\_CLK}$
- PDSCNT (USCI\_BRGEN [9:8])

- to define the length of a data sample time (division of  $f_{REF\_CLK}$  by 1, 2, 3, or 4)
- DSCNT (USCI\_BRGEN [14:10])  
to define the number of data sample time per bit time  
The standard setting is given by RCLKSEL = 0 ( $f_{REF\_CLK} = f_{PCLK}$ ), PTCLKSEL = 0 ( $f_{PROT\_CLK} = f_{REF\_CLK}$ ) and SPCLKSEL = 2'b00 ( $f_{SAMP\_CLK} = f_{DIV\_CLK}$ ). Under these conditions, the baud rate is given by:

$$f_{I2C} = f_{REF\_CLK} \times \frac{1}{CLKDIV + 1} \times \frac{1}{PDSCNT + 1} \times \frac{1}{DSCNT + 1}$$

In order to generate slower frequencies, additional divide-by-2 stages can be selected by PTCLKSEL = 1 ( $f_{PROT\_CLK} = f_{REF\_CLK2}$ ), leading to:

$$f_{I2C} = \frac{f_{REF\_CLK}}{2} \times \frac{1}{CLKDIV + 1} \times \frac{1}{PDSCNT + 1} \times \frac{1}{DSCNT + 1}$$

If SPCLKSEL = 2'b10 ( $f_{SAMP\_CLK} = f_{SCLK}$ ), and RCLKSEL = 0 ( $f_{REF\_CLK} = f_{PCLK}$ ), PTCLKSEL = 0 ( $f_{PROT\_CLK} = f_{REF\_CLK}$ ). The baud rate is given by:

$$f_{I2C} = f_{REF\_CLK} \times \frac{1}{CLKDIV + 1} \times \frac{1}{2} \times \frac{1}{PDSCNT + 1} \times \frac{1}{DSCNT + 1}$$

#### 6.26.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 (USCI\_PROTCTL [5]).

#### 6.26.5.7 Multi-master Arbitration

In some applications, there are two or more masters on the same I<sup>2</sup>C bus to access slaves, and the masters may transmit data simultaneously. The I<sup>2</sup>C supports multi-master by including collision detection and arbitration to prevent data corruption.

If two masters sometimes initiate I<sup>2</sup>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<sup>2</sup>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<sup>2</sup>C master must monitor the I<sup>2</sup>C bus for collisions and act accordingly. Figure 6.26-7 describes master1 data and master2 data are compete arbitration.



Figure 6.26-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 (USCI\_PROTSTS [11]) and can generate a protocol interrupt if enabled by ARBLOIEN (USCI\_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.26.5.8 Transmission Chain

The I<sup>2</sup>C bus protocol requiring a kind of in-bit-response during the arbitration phase and while a slave is transmitting, the resulting loop delay of the transmission chain can limit the reachable maximal baud rate, strongly depending on the bus characteristics (bus load, module frequency, etc.).

The shift clock SCL is generated by the master device, output on the wire, then it passes through the input stage and the input filter. Now, the edges can be detected and the SDA data signal can be generated accordingly. The SDA signal passes through the output stage and the wire to the master receiver part. There, it passes through the input stage and the input filter before it is sampled.

This complete loop has to be finished (including all settling times to obtain stable signal levels) before the SCL signal changes again. The delays in this path have to be taken into account for the calculation of the baud rate as a function of  $f_{PCLK}$  and  $f_{PROT\_CLK}$ . We suggest user adopt  $f_{PCLK}$ .

#### 6.26.5.9 Non-Acknowledge and Error Conditions

In case of a non-acknowledge (NACKIF (USCI\_PROTSTS [10])) or an error (ERRIF(USCI\_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.26.5.10 I<sup>2</sup>C Protocol Interrupt Events

The following protocol-related events are generated in I<sup>2</sup>C mode and can lead to a protocol interrupt.

Please note that the bits in register USCI\_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 (USCI\_PROTSTS [8]))
- STOP condition transferred at a correct position in a frame (STORIF (USCI\_PROTSTS [9]))
- Master arbitration lost (ARBLOIF (USCI\_PROTSTS [11]))
- Slave read requested (SLAREAD (USCI\_PROTSTS [15]))
- Acknowledge received (ACKIF (USCI\_PROTSTS [13]))
- Non-acknowledge received (NACKIF (USCI\_PROTSTS [10]))
- START condition not at the expected position in a frame (ERRIF (USCI\_PROTSTS [12]))
- STOP condition not at the expected position in a frame (ERRIF (USCI\_PROTSTS [12]))

#### 6.26.5.11 Operating the I<sup>2</sup>C

To operate the I<sup>2</sup>C protocol, the following issues have to be considered:

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

It is recommended to configure all parameters of the I<sup>2</sup>C that do not change during run time while FUNMODE (USCI\_CTL [2:0]) = 000B. The I<sup>2</sup>C control flow has to be done while FUNMODE (USCI\_CTL [2:0]) = 000B to avoid unintended edges of the input signals and the I<sup>2</sup>C mode can be enabled by FUNMODE (USCI\_CTL [2:0]) = 100B afterwards.

Step 1. Set FUNMODE (USCI\_CTL [2:0]) = 000B

Step 2. Set FUNMODE (USCI\_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<sup>2</sup>C bus lines.

**Note:** The step to enable the alternate output port functions should only be done after the I<sup>2</sup>C mode is enabled, to avoided unintended spikes on the output.

##### Bit Timing Configuration

In standard mode (100 kBit/s) a minimum module frequency of 2 MHz is necessary, whereas in fast mode (400 kBit/s) a minimum of 10 MHz is required. Additionally, if the digital filter stage should be used to eliminate spikes up to 50 ns, a filter frequency of 20 MHz is necessary. There could be an uncertainty in the SCL high phase timing of maximum  $1/f_{PROT\_CLK}$  if another I<sup>2</sup>C participant lengthens the SCL low phase on the bus. Note that the SCL maximum frequency is  $f_{SAMP\_CLK}/2$  and the SPCLKSEL (USCI\_BRGEN [3:2]) must be set to 0 for selecting  $f_{SAMP\_CLK} = f_{DIV\_CLK}$ .

##### Data Format Configuration

The data format has to be configured for 8 data bits (DWIDTH (USCI\_LINECTL [11:8]) = 8), and MSB shifted first (LSB (USCI\_LINECTL [0]) = 0). As a result, USCI\_LINECTL has to be set to 0x800.

##### Control Flow

The on-chip I<sup>2</sup>C ports support three operation modes, Master, Slave, and General Call Mode.

In a given application, I<sup>2</sup>C port may operate as a master or as a slave. In Slave mode, the I<sup>2</sup>C port hardware looks for its own slave address and the general call address. If one of these addresses is detected, and if the slave is willing to receive or transmit data from/to master(by setting the AA bit), acknowledge pulse will be transmitted out on the 9th clock, hence an interrupt is requested on both master and slave devices if interrupt is enabled. When the microcontroller wishes to become the bus master, hardware waits until the bus is free before entering Master mode so that a possible slave action is not be interrupted. If address arbitration is lost in Master mode, I<sup>2</sup>C port switches to Slave mode immediately and can detect its own slave address in the same serial transfer.

To control the I<sup>2</sup>C bus transfer in each mode, user needs to set USCI\_PROTCTL, USCI\_PROTIEN, TXDAT registers according to current status of USCI\_PROTSTS register. In other words, for each I<sup>2</sup>C

bus action, user needs to check current status by USCI\_PROTSTS register, and then set USCI\_PROTCTL, USCI\_PROTIEN, TXDAT registers to take bus action. Finally, check the response status by USCI\_PROTSTS.

The bits, STA, STO and AA in USCI\_PROTCTL register are used to control the next state of the I<sup>2</sup>C hardware after interrupt signal is cleared. Upon completion of the new action, a new status will be updated in USCI\_PROTSTS register will be set. If the I<sup>2</sup>C interrupt control bit of USCI\_PROTIEN is set, appropriate action or software branch of the new status can be performed in the Interrupt service routine.

Figure 6.26-8 shows the current I<sup>2</sup>C STARIF (USCI\_PROTSTS [8]) is set to 1 by hardware, and then set TXDAT = SLA+W (Slave address + Write bit), (PTRG, STA, STO, AA) = (1, 0, 0, x) to send the address to I<sup>2</sup>C bus, and write 1 to STARIF (USCI\_PROTSTS [8]) to clear flag. If a slave on the bus matches the address and response ACK, the USCI\_PROTSTS will be updated by ACKIF (USCI\_PROTSTS [13]) setting.



Figure 6.26-8 Control I<sup>2</sup>C Bus according to Current I<sup>2</sup>C Status

### Data Transfer on the I<sup>2</sup>C Bus

Figure 6.26-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.26-9 Master Transmits Data to Slave with a 7-bit Address

Figure 6.26-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.26-10 Master Reads Data from Slave with a 7-bit Address

Figure 6.26-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.26-11 Master Transmits Data to Slave by 10-bit Address

Figure 6.26-12 shows a master read data from slave by 10-bit address. A master addresses a slave with a 10-bit address. First master 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.26-12 Master Reads Data from Slave by 10-bit Address

### Master Mode

In Figure 6.26-13 and Figure 6.26-14, all possible protocols for I<sup>2</sup>C master are shown. User needs to follow proper path of the flow to implement required I<sup>2</sup>C protocol.

In other words, user can send a START signal to bus and I<sup>2</sup>C will be in Master Transmitter mode (Figure 6.26-13) or Master receiver mode (Figure 6.26-14) after START signal has been sent successfully and new status register would be set STARIF (USCI\_PROTSTS [8]). Followed by START signal, user can send slave address, read/write bit, data and Repeat START, STOP to perform I<sup>2</sup>C protocol.



Figure 6.26-13 Master Transmitter Mode Control Flow with 7-bit Address



Figure 6.26-14 Master Receiver Mode Control Flow with 7-bit Address



Figure 6.26-15 Master Transmitter Mode Control Flow with 10-bit Address



Figure 6.26-16 Master Receiver Mode Control Flow with 10-bit Address

If the I<sup>2</sup>C is in Master mode and gets arbitration lost, the bit of ARBLOIF (USCI\_PROTSTS [11]) will be set. User may writing 1 to ARBLOIF (USCI\_PROTSTS [11]) and set (PTRG, STA, STO, AA) = (1, 1, 0, X) to send START to re-start Master operation when bus become free. Otherwise, user may writing 1 to ARBLOIF (USCI\_PROTSTS [11]) and set (PTRG, STA, STO, AA) = (1, 0, 0, X) to release I<sup>2</sup>C bus and enter not addressed Slave mode.

## Slave Mode

When reset, I<sup>2</sup>C is not addressed and will not recognize the address on I<sup>2</sup>C bus. User can set device address by USCI\_DEVADDRn and set (PTRG, STA, STO, AA) = (1, 0, 0, 1) to let I<sup>2</sup>C recognize the address sent by master. Figure 6.26-17 shows all the possible flow for I<sup>2</sup>C in Slave mode. Users need to follow a proper flow (as shown in Figure 6.26-17) to implement their own I<sup>2</sup>C protocol.

If bus arbitration is lost in Master mode, I<sup>2</sup>C port switches to Slave mode immediately and can detect its own slave address in the same serial transfer. If the detected address is SLA+W (Master want to write data to Slave) or SLA+R (Master want to read data from Slave) after arbitration lost, the ARBLOIF will be set to 1.

**Note:** During I<sup>2</sup>C communication, the SCL clock will be released when writing '1' to PTRG (USCI\_PROTCTL[5]) in Slave mode.



Figure 6.26-17 Save Mode Control Flow with 7-bit Address



Figure 6.26-18 Save Mode Control Flow with 10-bit Address

If I<sup>2</sup>C is still transmitting and receiving data in addressed Slave mode but got a STOP or Repeat START, the register STORIF (USCI\_PROTSTS [9]) or STARIF (USCI\_PROTSTS [8]) will be set. User could follow the action for NACKIF (USCI\_PROTSTS [10]) as shown in the above figure when got STARIF (USCI\_PROTSTS [8]) is set.

**Note:** After slave gets interrupt flag of NACKIF (USCI\_PROTSTS [10]) and start/stop symbol including STARIF (USCI\_PROTSTS [8]) and STORIF (USCI\_PROTSTS [9]), slave can switch to not address mode and own SLA will not be recognized. If setting this interrupt flag, slave will not receive any I<sup>2</sup>C signal or address from master. At this status, I<sup>2</sup>C should be reset by setting FUNMODE (USCI\_CTL [2:0]) = 000B to leave this status.

#### General Call (GC) Mode

If the GCFUNC bit (USCI\_PROTCTL [0]) is set, the I<sup>2</sup>C port hardware will respond to General Call address (00H). User can clear GC bit to disable general call function. When the GC bit is set and the

I<sup>2</sup>C in slave mode, it can receive the general call address by 0x00 after master send general call address to I<sup>2</sup>C bus, and then it also will follow protocol status register.



Figure 6.26-19 GC Mode with 7-bit Address

If I<sup>2</sup>C is still receiving data in GC mode but got a STOP or Repeat START, the STORIF (USCI\_PROTSTS [9]) or STARIF (USCI\_PROTSTS [8]) will be set. User could follow the action for NACKIF (USCI\_PROTSTS [10]) in above figure when got STORIF (USCI\_PROTSTS [9]) or STARIF (USCI\_PROTSTS [8]) is set.

**Note:** After slave gets interrupt flag of NACKIF (USCI\_PROTSTS [10]) and start/stop symbol including STARIF (USCI\_PROTSTS [8]) and STORIF (USCI\_PROTSTS [9]), slave can switch to not address mode and own SLA will not be recognized. If setting this interrupt flag, slave will not receive any I<sup>2</sup>C signal or address from master. At this time, I<sup>2</sup>C controller should be reset by setting FUNMODE (USCI\_CTL [2:0]) = 000B to leave this status.

## Protocol Functional Description

### Monitor Mode

When I<sup>2</sup>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 (USCI\_PROTCTL [9]) is set. Note that the first interrupt will occur when initial START, it not the same as I<sup>2</sup>C slave, but the other interrupts are the same.

Subsequent to the address-match detection, interrupts will be generated after each data byte is received as slave mode control flow, or after each byte that the module believes it has transmitted for a slave-read transfer. In this second case, the data register will actually contain data transmitted by some other slave on the bus which was actually addressed by the master. If user wants to watch other device, user can set address mask and monitor.

If the monitor has not had time to respond to interrupt, the SCL signal will be pulled to low when SCLOUTEN (USCI\_PROTCTL [8]) is set to 1. User must set PTRG (USCI\_PROTCTL [5]) to release bus when SCLOUTEN (USCI\_PROTCTL [8]) is set to 1. If SCLOUTEN (USCI\_PROTCTL [8]) is not set to 1, user doesn't need to set PTRG (USCI\_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<sup>2</sup>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 (USCI\_TMCTL[24:16]) to configure hold time and STCTL (USCI\_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 I<sup>2</sup>C protocol. Once setup time configuration greater than design limitation, that means if setup time setting make SCL output less than three PCLKs, I<sup>2</sup>C controller can't work normally due to SCL must sample three times. And once hold time configuration greater than I<sup>2</sup>C clock limitation, I<sup>2</sup>C will occur bus error. Suggest that user calculate suitable timing with baud rate and protocol before setting timing. Table 6.26-1 shows the relationship between I<sup>2</sup>C baud rate and PCLK, the number of table represent one clock duty contain how many PCLKs. Setup and hold time configuration even can program some extreme values in the design, but user should follow I<sup>2</sup>C protocol standard.

| I <sup>2</sup> C Baud Rate<br>PCLK | 100k | 200k | 400k | 800k | 1200k |
|------------------------------------|------|------|------|------|-------|
| 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.26-1 Relationship between I<sup>2</sup>C Baud Rate and PCLK

For setup time wrong adjustment example, assuming one SCL cycle contains ten PCLKs and set STCTL (USCI\_TMCTL[8:0]) to 3 that stretch three PCLKs for setup time setting. The setup time setting limitation:  $ST_{limit} = (USCI_BRGEN[25:16]+1) - 6$ .



Figure 6.26-20 Setup Time Wrong Adjustment

For hold time wrong adjustment example, use I<sup>2</sup>C Baud Rate = 1200k and PCLK = 72MHz, the SCL high/low duty = 60 PCLK. When HTCTL (USCI\_TMCTL[24:16]) is set to 63 and STCTL (USCI\_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} = (USCI_BRGEN[25:16]+1) - 9$ .



Figure 6.26-21 Hold Time Wrong Adjustment

### I<sup>2</sup>C Time-out Function

There is a 10 bits time-out counter TOCNT (USCI\_PROTCTL [25:16]) which can be used to deal with the I<sup>2</sup>C bus hang-up. If the time-out counter is enabled, the counter starts up counting until it equals TOCNT (USCI\_PROTCTL [25:16]) and generates I<sup>2</sup>C interrupt to CPU or stops counting by clearing TOIEN (USCI\_PROTIEN [0]) to 0 or setting all I<sup>2</sup>C interrupt signal (ACKIF, ERRIF, ARBLOIF, NACKIF, STORIF, STARIF). User may write 1 to clear TOIF(USCI\_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.26-22 for the time-out counter TOCNT (USCI\_PROTCTL [25:16]).  $T_{TOCNT} = (TOCNT (USCI_PROTCTL [25:16]) + 1) \times 32$  (5-bit)  $\times T_{PCLK}$ . Note that the time counter clock source TMCNTSRC (USCI\_BRGEN [5]) must be set as 0.

Figure 6.26-22 I<sup>2</sup>C Time-out Count Block Diagram

### Wake-up Function

When chip enters Power-down mode and set WKEN (WKCTL[0]) to 1, other I<sup>2</sup>C master can wake up the chip by addressing the I<sup>2</sup>C device, user must configure the related setting before entering sleep mode. The ACK bit cycle of address match frame is done in power-down. The controller will stretch the SCL to low when the address is matched the device's address and the ACK cycle done. The SCL is stretched until the bit is clear by user. If the frequency of SCL is low speed and the system has wakeup from address match frame, the user shall check this bit to confirm this frame has transaction done and then to do the wake-up procedure. Therefore, when the chip is woken up by address match with one of the device address register (USCI\_DEVADDRn), the user shall check the WKAKDONE (USCI\_PROTSTS [16]) bit is set to 1 to confirm the address wakeup frame has done. The WKAKDONE bit indicates that the ACK bit cycle of address 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 (USCI\_PROTSTS [17]) bit records the Read/Write command on the address match wake-up frame. The user can use read this bit's status to prepare the next transmitted data (WRSTSWK = 0) or to wait the incoming data (WRSTSWK = 1) can be stored in time after the system is wake-up by the address match frame.

When system is woken up by other I<sup>2</sup>C master device, WKF (USCI\_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 USCI0\_I<sup>2</sup>C related registers when using I<sup>2</sup>C protocol to read data from EEPROM.

1. Set USCI0\_I<sup>2</sup>C the multi-function pin as SCL and SDA pins The muti-function configuration reference Basic Configuration.
2. Enable USCI0 APB clock. The muti-function configuration reference Basic Configuration.
3. Set USCI0RST=1 to reset USCI controller then set USCI0RST=0 let USCI controller to normal operation, The reset controller configuration reference Basic Configuration.
4. Set FUNMODE =100 to enable USCI0\_I<sup>2</sup>C controller in the "USCI\_CTL" register.
5. Give USCI0\_I<sup>2</sup>C clock a divided register value for USCI0\_I<sup>2</sup>C clock rate in the "USCI\_BRGEN".
6. Enable system I2C0 IRQ in system "NVIC" control register.
7. Set ACKIEN, ERRIEN, ARBLOIEN, NACKIEN, STORIEN, STARLEN, and TOIEN to enable I<sup>2</sup>C Interrupt in the "USCI\_PROTIEN" register.

8. Set USCI address registers “USCI\_ADDR0 ~ USCI\_ADDR1”.

Random read operation is one of the methods of access EEPROM. The method allows the master to access any address of EEPROM space. Figure 6.26-23 shows the EEPROM random read operation.



Figure 6.26-23 EEPROM Random Read

Figure 6.26-24 shows how to use I<sup>2</sup>C controller to implement the protocol of EEPROM random read.



Figure 6.26-24 Protocol of EEPROM Random Read

The I<sup>2</sup>C controller, which is a master, sends START to bus. Then, it sends a SLA+W (Slave address + Write bit) to EEPROM 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.26.6 Register Map

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

| Register                                                | Offset                     | R/W | Description                                        | Reset Value |
|---------------------------------------------------------|----------------------------|-----|----------------------------------------------------|-------------|
| <b>USCI Base Address:</b>                               |                            |     |                                                    |             |
| <b>USCI<sub>n</sub>_BA = 0x400D_0000 + (0x1000 * n)</b> |                            |     |                                                    |             |
| n= 0, 1                                                 |                            |     |                                                    |             |
| <b>USCI_CTL</b>                                         | USCI <sub>n</sub> _BA+0x00 | R/W | USCI Control Register                              | 0x0000_0000 |
| <b>USCI_BRGEN</b>                                       | USCI <sub>n</sub> _BA+0x08 | R/W | USCI Baud Rate Generator Register                  | 0x0000_3C00 |
| <b>USCI_LINECTL</b>                                     | USCI <sub>n</sub> _BA+0x2C | R/W | USCI Line Control Register                         | 0x0000_0000 |
| <b>USCI_TXDAT</b>                                       | USCI <sub>n</sub> _BA+0x30 | W   | USCI Transmit Data Register                        | 0x0000_0000 |
| <b>USCI_RXDAT</b>                                       | USCI <sub>n</sub> _BA+0x34 | R   | USCI Receive Data Register                         | 0x0000_0000 |
| <b>USCI_DEVADDR0</b>                                    | USCI <sub>n</sub> _BA+0x44 | R/W | USCI Device Address Register 0                     | 0x0000_0000 |
| <b>USCI_DEVADDR1</b>                                    | USCI <sub>n</sub> _BA+0x48 | R/W | USCI Device Address Register 1                     | 0x0000_0000 |
| <b>USCI_ADDRMSK0</b>                                    | USCI <sub>n</sub> _BA+0x4C | R/W | USCI Device Address Mask Register 0                | 0x0000_0000 |
| <b>USCI_ADDRMSK1</b>                                    | USCI <sub>n</sub> _BA+0x50 | R/W | USCI Device Address Mask Register 1                | 0x0000_0000 |
| <b>USCI_WKCTL</b>                                       | USCI <sub>n</sub> _BA+0x54 | R/W | USCI Wake-up Control Register                      | 0x0000_0000 |
| <b>USCI_WKSTS</b>                                       | USCI <sub>n</sub> _BA+0x58 | R/W | USCI Wake-up Status Register                       | 0x0000_0000 |
| <b>USCI_PROTCTL</b>                                     | USCI <sub>n</sub> _BA+0x5C | R/W | USCI Protocol Control Register                     | 0x0000_0000 |
| <b>USCI_PROTIEN</b>                                     | USCI <sub>n</sub> _BA+0x60 | R/W | USCI Protocol Interrupt Enable Register            | 0x0000_0000 |
| <b>USCI_PROTSTS</b>                                     | USCI <sub>n</sub> _BA+0x64 | R/W | USCI Protocol Status Register                      | 0x0000_0000 |
| <b>USCI_TMCTL</b>                                       | USCI <sub>n</sub> _BA+0x8C | R/W | I <sup>2</sup> C Timing Configure Control Register | 0x0000_0000 |

### 6.26.7 Register Description

#### USCI Control Register (USCI\_CTL)

| Register | Offset         | R/W | Description           |  |  |  |  | Reset Value |
|----------|----------------|-----|-----------------------|--|--|--|--|-------------|
| USCI_CTL | USCIIn_BA+0x00 | R/W | USCI Control Register |  |  |  |  | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [2:0]  | FUNMODE     | <p><b>Function Mode</b></p> <p>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.</p> <p>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<sup>2</sup>C protocol is selected.</p> <p><b>Note:</b> Other bit combinations are reserved.</p> |

USCI Baud Rate Generator Register (USCI\_BRGEN)

| Register   | Offset         | R/W | Description                       |  |  |  | Reset Value |
|------------|----------------|-----|-----------------------------------|--|--|--|-------------|
| USCI_BRGEN | USCIIn_BA+0x08 | R/W | USCI Baud Rate Generator Register |  |  |  | 0x0000_3C00 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| [25:16] | CLKDIV      | <b>Clock Divider</b><br>This bit field defines the ratio between the protocol clock frequency $f_{PROT\_CLK}$ and the clock divider frequency $f_{DIV\_CLK}$ ( $f_{DIV\_CLK} = f_{PROT\_CLK} / (\text{CLKDIV} + 1)$ ).                                                                                                                               |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| [14:10] | DSCNT       | <b>Denominator for Sample Counter</b><br>This bit field defines the divide ratio of the sample clock $f_{SAMP\_CLK}$ .<br>The divided frequency $f_{DS\_CNT} = f_{PDS\_CNT} / (\text{DSCNT} + 1)$ .<br><b>Note:</b> 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      | <b>Pre-divider for Sample Counter</b><br>This bit field defines the divide ratio of the clock division from sample clock $f_{SAMP\_CLK}$ . The divided frequency $f_{PDS\_CNT} = f_{SAMP\_CLK} / (\text{PDSCNT} + 1)$ .                                                                                                                              |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| [5]     | TMCNTSRC    | <b>Time Measurement Counter Clock Source Selection</b><br>0 = Time measurement counter with $f_{PROT\_CLK}$ .<br>1 = Time measurement counter with $f_{DIV\_CLK}$ .                                                                                                                                                                                  |
| [4]     | TMCNTEN     | <b>Time Measurement Counter Enable Bit</b><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    | <b>Sample Clock Source Selection</b><br>This bit field used for the clock source selection of a sample clock ( $f_{SAMP\_CLK}$ ) for the protocol processor.<br>00 = $f_{SAMP\_CLK} = f_{DIV\_CLK}$ .<br>01 = $f_{SAMP\_CLK} = f_{PROT\_CLK}$ .<br>10 = $f_{SAMP\_CLK} = f_{SCLK}$ .                                                                 |

|     |                 |                                                                                                                                                                                                                                |
|-----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | $11 = f_{SAMP\_CLK} = f_{REF\_CLK}$ .                                                                                                                                                                                          |
| [1] | <b>PTCLKSEL</b> | <b>Protocol Clock Source Selection</b><br>This bit selects the source signal of protocol clock ( $f_{PROT\_CLK}$ ).<br>0 = Reference clock $f_{REF\_CLK}$ .<br>1 = $f_{REF\_CLK2}$ (its frequency is half of $f_{REF\_CLK}$ ). |
| [0] | <b>RCLKSEL</b>  | <b>Reference Clock Source Selection</b><br>This bit selects the source signal of reference clock ( $f_{REF\_CLK}$ ).<br>0 = Peripheral device clock $f_{PCLK}$ .<br>1 = Reserved.                                              |

USCI Line Control Register (USCI\_LINECTL)

| Register     | Offset         | R/W | Description                |  |  |  | Reset Value |
|--------------|----------------|-----|----------------------------|--|--|--|-------------|
| USCI_LINECTL | USCIIn_BA+0x2C | R/W | USCI Line Control Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [11:8]  | <b>DWIDTH</b>   | <p><b>Word Length of Transmission</b></p> <p>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.</p> <p>0x0: The data word contains 16 bits located at bit positions [15:0].</p> <p>0x1: Reserved.</p> <p>0x2: Reserved.</p> <p>0x3: Reserved.</p> <p>0x4: The data word contains 4 bits located at bit positions [3:0].</p> <p>0x5: The data word contains 5 bits located at bit positions [4:0].</p> <p>...</p> <p>0xF: The data word contains 15 bits located at bit positions [14:0].</p> |
| [7:1]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [0]     | <b>LSB</b>      | <p><b>LSB First Transmission Selection</b></p> <p>0 = The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is transmitted/received first.</p> <p>1 = The LSB, the bit 0 of data buffer, will be transmitted/received first.</p>                                                                                                                                                                                                                                                                                                                                                                              |

**USCI Transmit Data Register (USCI\_TXDAT)**

| Register   | Offset         | R/W | Description                 | Reset Value |
|------------|----------------|-----|-----------------------------|-------------|
| USCI_TXDAT | USCIIn_BA+0x30 | W   | USCI Transmit Data Register | 0x0000_0000 |



| Bits    | Description |                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                               |
| [15:0]  | TXDAT       | <b>Transmit Data</b><br>Software can use this bit field to write 16-bit transmit data for transmission. |

**USCI Receive Data Register (USCI\_RXDAT)**

| Register   | Offset         | R/W | Description                |  |  |  | Reset Value |
|------------|----------------|-----|----------------------------|--|--|--|-------------|
| USCI_RXDAT | USCIIn_BA+0x34 | R   | USCI Receive Data Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                     |
| [15:0]  | RXDAT       | <p><b>Received Data</b></p> <p>This bit field monitors the received data which stored in receive data buffer.</p> <p><b>Note:</b> In I<sup>2</sup>C protocol, RXDAT[12:8] indicate the different transmission conditions which defined in I<sup>2</sup>C.</p> |

**USCI Device Address Register (USCI\_DEVADDR)**

| Register             | Offset                     | R/W | Description                    | Reset Value |
|----------------------|----------------------------|-----|--------------------------------|-------------|
| <b>USCI_DEVADDR0</b> | USCI <sub>n</sub> _BA+0x44 | R/W | USCI Device Address Register 0 | 0x0000_0000 |
| <b>USCI_DEVADDR1</b> | USCI <sub>n</sub> _BA+0x48 | R/W | USCI Device Address Register 1 | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [9:0]   | DEVADDR     | <p><b>Device Address</b><br/>           In I<sup>2</sup>C protocol, this bit field contains the programmed slave address. If the first received address byte are 1111 0AA<sub>B</sub>X<sub>B</sub>, 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].</p> <p><b>Note 1:</b> The DEVADDR [9:7] must be set 3'b000 when I<sup>2</sup>C operating in 7-bit address mode.</p> <p><b>Note 2:</b> When software set 10'h000, the address can not be used.</p> |

**USCI Device Address Mask Register (USCI\_ADDRMSK) – for I<sup>2</sup>C Only**

| Register             | Offset                     | R/W | Description                         | Reset Value |
|----------------------|----------------------------|-----|-------------------------------------|-------------|
| <b>USCI_ADDRMSK0</b> | USCI <sub>n</sub> _BA+0x4C | R/W | USCI Device Address Mask Register 0 | 0x0000_0000 |
| <b>USCI_ADDRMSK1</b> | USCI <sub>n</sub> _BA+0x50 | R/W | USCI Device Address Mask Register 1 | 0x0000_0000 |



| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [9:0]   | <b>ADDRMSK</b>  | <p><b>USCI Device Address Mask</b></p> <p>0 = Mask Disabled (the received corresponding register bit should be exact the same as address register.).</p> <p>1 = Mask Enabled (the received corresponding address bit is don't care.).</p> <p>USCI support multiple address recognition with two address mask register. When the bit in the address mask register is set to one, it means the received corresponding address bit is don't-care. If the bit is set to zero, that means the received corresponding register bit should be exact the same as address register.</p> <p><b>Note:</b> The wake-up function can not use address mask.</p> |

**USCI Wake-up Control Register (USCI\_WKCTL)**

| Register   | Offset         | R/W | Description                   |  |  |  |  | Reset Value |
|------------|----------------|-----|-------------------------------|--|--|--|--|-------------|
| USCI_WKCTL | USCIIn_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 |

| Bits   | Description |                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                       |
| [1]    | WKADDREN    | <b>Wake-up Address Match Enable Bit</b><br>0 = The chip is woken up according data toggle.<br>1 = The chip is woken up according address match. |
| [0]    | WKEN        | <b>Wake-up Enable Bit</b><br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                    |

USCI Wake-up Status Register (USCI\_WKSTS)

| Register   | Offset         | R/W | Description                  |  |  |  |  | Reset Value |
|------------|----------------|-----|------------------------------|--|--|--|--|-------------|
| USCI_WKSTS | USCIIn_BA+0x58 | R/W | USCI Wake-up Status Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                        |
| [0]    | WKF         | <b>Wake-up Flag</b><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 – I<sup>2</sup>C (USCI\_PROTCTL)

| Register     | Offset                     | R/W | Description                    |  |  |  | Reset Value |
|--------------|----------------------------|-----|--------------------------------|--|--|--|-------------|
| USCI_PROTCTL | USCI <sub>n</sub> _BA+0x5C | R/W | USCI Protocol Control Register |  |  |  | 0x0000_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      | I <sup>2</sup> C Protocol Enable Bit<br>0 = I <sup>2</sup> C Protocol Disabled.<br>1 = I <sup>2</sup> C Protocol Enabled.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [30:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [25:16] | TOCNT       | <b>Time-out Clock Cycle</b><br>This bit field indicates how many clock cycle selected by TMCNTSRC (USCI_BRGEN [5]) when each interrupt flags are clear. The time-out is enable when TOCNT bigger than 0.<br><b>Note:</b> The TMCNTSRC (USCI_BRGEN [5]) must be set zero on I <sup>2</sup> C mode.                                                                                                                                                                                                                         |
| [15:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [9]     | MONEN       | <b>Monitor Mode Enable Bit</b><br>This bit enables monitor mode. In monitor mode the SDA output will be put in high impedance mode. This prevents the I <sup>2</sup> C module from outputting data of any kind (including ACK) onto the I <sup>2</sup> C data bus.<br>0 = The monitor mode Disabled.<br>1 = The monitor mode Enabled.<br><b>Note:</b> Depending on the state of the SCLOUTEN bit, the SCL output may be also forced high, preventing the module from having control over the I <sup>2</sup> C clock line. |
| [8]     | SCLOUTEN    | <b>SCL Output Enable Bit</b><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 <sup>2</sup> C interrupt.<br>0 = SCL output will be forced high due to open drain mechanism.<br>1 = I <sup>2</sup> C module may act as a slave peripheral just like in normal operation, the I <sup>2</sup> C holds the clock line low until it has had time to clear I <sup>2</sup> C interrupt.                                                                 |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5] | <b>PTRG</b>     | <b>I<sup>2</sup>C Protocol Trigger (Write Only)</b><br>When a new state is present in the USCI_PROTSTS register, if the related interrupt enable bits are set, the I <sup>2</sup> C interrupt is requested. It must write one by software to this bit after the related interrupt flags are set to 1 and the I <sup>2</sup> C protocol function will go ahead until the STOP is active or the PROTEN is disabled.<br>0 = I <sup>2</sup> C's stretch disabled and the I <sup>2</sup> C protocol function will go ahead.<br>1 = I <sup>2</sup> C's stretch active. |
| [4] | <b>ADDR10EN</b> | <b>Address 10-bit Function Enable Bit</b><br>0 = Address match 10 bit function Disabled.<br>1 = Address match 10 bit function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [3] | <b>STA</b>      | <b>I<sup>2</sup>C START Control</b><br>Setting STA to logic 1 to enter Master mode, the I <sup>2</sup> C hardware sends a START or repeat START condition to bus when the bus is free.                                                                                                                                                                                                                                                                                                                                                                           |
| [2] | <b>STO</b>      | <b>I<sup>2</sup>C STOP Control</b><br>In Master mode, setting STO to transmit a STOP condition to bus then I <sup>2</sup> C hardware will check the bus condition if a STOP condition is detected this bit will be cleared by hardware automatically. In a slave mode, setting STO resets I <sup>2</sup> C hardware to the defined "not addressed" slave mode when bus error (USCI_PROTSTS.ERRIF = 1).                                                                                                                                                           |
| [1] | <b>AA</b>       | <b>Assert Acknowledge Control</b><br>When AA =1 prior to address or data received, an acknowledged (low level to SDA) will be returned during the acknowledge clock pulse on the SCL line when 1.) A slave is acknowledging the address sent from master, 2.) The receiver devices are acknowledging the data sent by transmitter. When AA=0 prior to address or data received, a Not acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on the SCL line.                                                                      |
| [0] | <b>GCFUNC</b>   | <b>General Call Function</b><br>0 = General Call Function Disabled.<br>1 = General Call Function Enabled.<br><b>Note:</b> When ADDR10EN (USCI_PROTCTL [4]) is set, don't set this bit.                                                                                                                                                                                                                                                                                                                                                                           |

**USCI Protocol Interrupt Enable Register – I<sup>2</sup>C (USCI\_PROTIEN)**

| Register     | Offset         | R/W | Description                             |  |  |  | Reset Value |
|--------------|----------------|-----|-----------------------------------------|--|--|--|-------------|
| USCI_PROTIEN | USCIIn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                        |
| [6]    | ACKIEN      | <b>Acknowledge Interrupt Enable Bit</b><br>This bit enables the generation of a protocol interrupt if an acknowledge is detected by a master.<br>0 = The acknowledge interrupt Disabled.<br>1 = The acknowledge interrupt Enabled.                               |
| [5]    | ERRIEN      | <b>Error Interrupt Enable Bit</b><br>This bit enables the generation of a protocol interrupt if an I <sup>2</sup> C error condition is detected (indicated by ERR (USCI_PROTSTS [16])).<br>0 = The error interrupt Disabled.<br>1 = The error interrupt Enabled. |
| [4]    | ARBLOIEN    | <b>Arbitration Lost Interrupt Enable Bit</b><br>This bit enables the generation of a protocol interrupt if an arbitration lost event is detected.<br>0 = The arbitration lost interrupt Disabled.<br>1 = The arbitration lost interrupt Enabled.                 |
| [3]    | NACKIEN     | <b>Non - Acknowledge Interrupt Enable Bit</b><br>This bit enables the generation of a protocol interrupt if a Non - acknowledge is detected by a master.<br>0 = The non - acknowledge interrupt Disabled.<br>1 = The non - acknowledge interrupt Enabled.        |
| [2]    | STORIEN     | <b>STOP Condition Received Interrupt Enable Bit</b><br>This bit enables the generation of a protocol interrupt if a STOP condition is detected.<br>0 = The stop condition interrupt Disabled.<br>1 = The stop condition interrupt Enabled.                       |
| [1]    | STARIENT    | <b>START Condition Received Interrupt Enable Bit</b><br>This bit enables the generation of a protocol interrupt if a START condition is detected.                                                                                                                |

|     |              |                                                                                                                                                                                                                             |
|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |              | 0 = The start condition interrupt Disabled.<br>1 = The start condition interrupt Enabled.                                                                                                                                   |
| [0] | <b>TOIEN</b> | <b>Time-out Interrupt Enable Bit</b><br>In I <sup>2</sup> 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<sup>2</sup>C (USCI PROTSTS)**

| Register     | Offset         | R/W | Description                   |  |  |  | Reset Value |
|--------------|----------------|-----|-------------------------------|--|--|--|-------------|
| USCI_PROTSTS | USCIIn_BA+0x64 | R/W | USCI Protocol Status Register |  |  |  | 0x0000_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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [19]    | <b>ERRARBLO</b> | <p><b>Error Arbitration Lost</b><br/> This bit indicates bus arbitration lost due to bigger noise which is can't be filtered by input processor. The I<sup>2</sup>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/> <b>Note:</b> This bit has no interrupt signal, and it will be cleared automatically by hardware when a START condition is present.</p>         |
| [18]    | <b>BUSHANG</b>  | <p><b>Bus Hang-up</b><br/> This bit indicates bus hang-up status. There is 4-bit counter count when SCL hold high and refer f<sub>SAMP_CLK</sub>. 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/> <b>Note:</b> This bit has no interrupt signal, and it will be cleared automatically by hardware when a START condition is present.</p> |
| [17]    | <b>WRSTSWK</b>  | <p><b>Read/Write Status Bit in Address Wake-up Frame</b><br/> 0 = Write command be record on the address match wake-up frame.<br/> 1 = Read command be record on the address match wake-up frame.</p>                                                                                                                                                                                                                                                                                                                                        |
| [16]    | <b>WKAKDONE</b> | <p><b>Wake-up Address Frame Acknowledge Bit Done</b><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/> <b>Note:</b> This bit can't release when WKUPIF is set.</p>                                                                                                                                                                                                                                                                                 |
| [15]    | <b>SLAREAD</b>  | <p><b>Slave Read Request Status</b><br/> This bit indicates that a slave read request has been detected.<br/> 0 = A slave R/W bit is 1 has not been detected.<br/> 1 = A slave R/W bit is 1 has been detected.</p>                                                                                                                                                                                                                                                                                                                           |

|      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 | <b>Note:</b> This bit has no interrupt signal, and it will be cleared automatically by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [14] | <b>SLASEL</b>   | <p><b>Slave Select Status</b><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.</p> <p><b>Note:</b> This bit has no interrupt signal, and it will be cleared automatically by hardware.</p>                                                                                                                                                                                                                                                                                                                                                                                   |
| [13] | <b>ACKIF</b>    | <p><b>Acknowledge Received Interrupt Flag</b><br/> This bit indicates that an acknowledge has been received in master mode. A protocol interrupt can be generated if USCI_PROTCTL.ACKIEN = 1.<br/> 0 = An acknowledge has not been received.<br/> 1 = An acknowledge has been received.</p> <p><b>Note:</b> It is cleared by software writing 1 into this bit</p>                                                                                                                                                                                                                                                                                                                        |
| [12] | <b>ERRIF</b>    | <p><b>Error Interrupt Flag</b><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 USCI_PROTCTL.ERRIEN = 1.<br/> 0 = An I<sup>2</sup>C error has not been detected.<br/> 1 = An I<sup>2</sup>C error has been detected.</p> <p><b>Note1:</b> It is cleared by software writing 1 into this bit<br/> <b>Note2:</b> This bit is set for slave mode, and user must write 1 into STO register to the defined "not addressed" slave mode.</p> |
| [11] | <b>ARBLOIF</b>  | <p><b>Arbitration Lost Interrupt Flag</b><br/> This bit indicates that an arbitration has been lost. A protocol interrupt can be generated if USCI_PROTCTL.ARBLIOEN = 1.<br/> 0 = An arbitration has not been lost.<br/> 1 = An arbitration has been lost.</p> <p><b>Note:</b> It is cleared by software writing 1 into this bit</p>                                                                                                                                                                                                                                                                                                                                                     |
| [10] | <b>NACKIF</b>   | <p><b>Non - Acknowledge Received Interrupt Flag</b><br/> This bit indicates that a non - acknowledge has been received in master mode. A protocol interrupt can be generated if USCI_PROTCTL.NACKIEN = 1.<br/> 0 = A non - acknowledge has not been received.<br/> 1 = A non - acknowledge has been received.</p> <p><b>Note:</b> It is cleared by software writing 1 into this bit</p>                                                                                                                                                                                                                                                                                                  |
| [9]  | <b>STORIF</b>   | <p><b>Stop Condition Received Interrupt Flag</b><br/> This bit indicates that a stop condition has been detected on the I<sup>2</sup>C bus lines. A protocol interrupt can be generated if USCI_PROTCTL.STORIEN = 1.<br/> 0 = A stop condition has not yet been detected.<br/> 1 = A stop condition has been detected.</p> <p><b>Note1:</b> It is cleared by software writing 1 into this bit</p>                                                                                                                                                                                                                                                                                        |
| [8]  | <b>STARIF</b>   | <p><b>Start Condition Received Interrupt Flag</b><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.</p> <p>A protocol interrupt can be generated if USCI_PROTCTL.STARIEN = 1.<br/> 0 = A start condition has not yet been detected.<br/> 1 = A start condition has been detected.</p> <p><b>Note:</b> It is cleared by software writing 1 into this bit</p>                                                                                                                                                                 |
| [7]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|     |                 |                                                                                                                                                                                                                                                                                |
|-----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | <b>ONBUSY</b>   | <b>On Bus Busy</b><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] | <b>TOIF</b>     | <b>Time-out Interrupt Flag</b><br>0 = A time-out interrupt status has not occurred.<br>1 = A time-out interrupt status has occurred.<br><b>Note:</b> It is cleared by software writing 1 into this bit                                                                         |
| [0] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                      |

**USCI Timing Configure Control Register (USCI\_TMCTL)**

| Register   | Offset       | R/W | Description                                        | Reset Value |
|------------|--------------|-----|----------------------------------------------------|-------------|
| USCI_TMCTL | USCI_BA+0x8C | R/W | I <sup>2</sup> C Timing Configure Control Register | 0x0000_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] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                             |
| [24:16] | <b>HTCTL</b>    | <b>Hold Time Configure Control</b><br>This field is used to generate the delay timing between SCL falling edge SDA edge in transmission mode.<br>The delay hold time is numbers of peripheral clock = HTCTL x f <sub>PCLK</sub> .     |
| [15:9]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                             |
| [8:0]   | <b>STCTL</b>    | <b>Setup Time Configure Control</b><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 <sub>PCLK</sub> . |

## 6.27 Controller Area Network (CAN)

### 6.27.1 Overview

The C\_CAN consists of the CAN Core, Message RAM, Message Handler, Control Registers and Module Interface. The CAN Core performs communication according to the CAN protocol version 2.0 part A and B. The bit rate can be programmed to values up to 1MBit/s. For the connection to the physical layer, additional transceiver hardware is required.

For communication on a CAN network, individual Message Objects are configured. The Message Objects and Identifier Masks for acceptance filtering of received messages are stored in the Message RAM. All functions concerning the handling of messages are implemented in the Message Handler. These functions include acceptance filtering, the transfer of messages between the CAN Core and the Message RAM, and the handling of transmission requests as well as the generation of the module interrupt.

The register set of the C\_CAN can be accessed directly by the software through the module interface. These registers are used to control/configure the CAN Core and the Message Handler and to access the Message RAM.

### 6.27.2 Features

- Supports CAN protocol version 2.0 part A and B
- Bit rates up to 1 MBit/s
- 32 Message Objects
- Each Message Object has its own identifier mask
- Programmable FIFO mode (concatenation of Message Objects)
- Maskable interrupt
- Disabled Automatic Re-transmission mode for Time Triggered CAN applications
- Programmable loop-back mode for self-test operation
- 16-bit module interfaces to the AMBA APB bus
- Supports wake-up function

### 6.27.3 Block Diagram

The C\_CAN interfaces with the AMBA APB bus. Figure 6.27-1 shows the block diagram of the C\_CAN.

- CAN Core
  - CAN Protocol Controller and Rx/Tx Shift Register for serial/parallel conversion of messages.
- Message RAM
  - Stores Message Objects and Identifier Masks
- Registers
  - All registers used to control and to configure the C\_CAN.
  - Message Handler
  - State Machine that controls the data transfer between the Rx/Tx Shift Register of the CAN Core and the Message RAM as well as the generation of interrupts as programmed in the Control and Configuration Registers.
- Module Interface

- C\_CAN interfaces to the AMBA APB 16-bit bus from CPU.



Figure 6.27-1 CAN Peripheral Block Diagram

#### 6.27.4 Basic Configuration

##### 6.27.4.1 CAN0 Basic Configuration

- Clock source Configuration
  - Enable CAN clock (CAN\_EN (APBCLK0[24])).
- Reset Configuration
  - Reset CAN controller (CAN\_RST (IPRSTC2[24])).
- Pin Configuration

| Group | Pin Name | GPIO         | MFP   |
|-------|----------|--------------|-------|
| CAN0  | CAN0_RXD | PD.10, PE.15 | MFP4  |
|       |          | PA.13        | MFP6  |
|       |          | PB.10        | MFP8  |
|       |          | PA.4, PC.4   | MFP10 |
|       | CAN0_TXD | PD.11, PE.14 | MFP4  |
|       |          | PA.12        | MFP6  |
|       |          | PB.11        | MFP8  |

|  |            |       |
|--|------------|-------|
|  | PA.5, PC.5 | MFP10 |
|--|------------|-------|

#### 6.27.4.2 CAN1 Basic Configuration

- Clock source Configuration
  - Enable CAN clock (CAN\_EN (APBCLK0[25])).
- Reset Configuration
  - Reset CAN controller (CAN\_RST (IPRSTC2[25])).
- Pin Configuration

| Group | Pin Name | GPIO        | MFP   |
|-------|----------|-------------|-------|
| CAN1  | CAN1_RXD | PB.6, PD.12 | MFP5  |
|       |          | PG.1        | MFP7  |
|       |          | PC.9, PE.6  | MFP9  |
|       |          | PC.2        | MFP10 |
|       | CAN1_TXD | PB.7, PC.13 | MFP5  |
|       |          | PG.0        | MFP7  |
|       |          | PC.10, PE.7 | MFP9  |
|       |          | PC.3        | MFP10 |

#### 6.27.5 Functional Description

##### 6.27.5.1 Software Initialization

The software initialization is started by setting the Init bit (CAN\_CON[0]), either by a software or a hardware reset, or by going to bus-off state.

While the Init bit is set, all messages transfer to and from the CAN bus are stopped and the status of the CAN\_TX output pin is recessive (HIGH). The Error Management Logic (EML) counters are unchanged. Setting the Init bit does not change any configuration register.

To initialize the CAN Controller, software has to set up the Bit Timing Register and each Message Object. If a Message Object is not required, the corresponding MsgVal bit (CAN\_IFn\_ARB2[15]) should be cleared. Otherwise, the entire Message Object has to be initialized.

Access to the Bit Timing Register and to the Baud Rate Prescaler Extension Register for configuring bit timing is enabled when both the Init and CCE (CAN\_CON[6]) bits are set.

Resetting the Init bit (by software only) finishes the software initialization. Later, the Bit Stream Processor (BSP) (see Section 6.27.7.15: Configuring the Bit Timing) synchronizes itself to the data transfer on the CAN bus by waiting for the occurrence of a sequence of 11 consecutive recessive bits (= Bus Idle) before it can take part in bus activities and start the message transfer.

The initialization of the Message Objects is independent of Init and can be done on the fly, but the Message Objects should all be configured to particular identifiers or set to not valid before the BSP starts the message transfer.

To change the configuration of a Message Object during normal operation, the software has to start by resetting the corresponding MsgVal bit. When the configuration is completed, MsgVal bit is set again.

##### 6.27.5.2 CAN Message Transfer

Once the C\_CAN is initialized and Init bit (CAN\_CON[0]) is reset to zero, the C\_CAN Core synchronizes itself to the CAN bus and starts the message transfer.

Received messages are stored in their appropriate Message Objects if they pass the Message Handler's acceptance filtering. The whole message including all arbitration bits, DLC (CAN\_IFn\_MCON[3:0]) and eight data bytes (CAN\_IFn\_DAT\_A1/2; CAN\_IFn\_DAT\_B1/2) are stored in the Message Object. If the Identifier Mask is used, the arbitration bits which are masked to "don't care" may be overwritten in the Message Object.

Software can read or write each message any time through the Interface Registers and the Message Handler guarantees data consistency in case of concurrent accesses.

Messages to be transmitted are updated by the application software. If a permanent Message Object (arbitration and control bits are set during configuration) exists for the message, only the data bytes are updated and the TxRqst bit (CAN\_IFn\_MCON[8]) with NewDat bit (CAN\_IFn\_MCON[15]) are set to start the transmission. If several transmit messages are assigned to the same Message Object (when the number of Message Objects is not sufficient), the whole Message Object has to be configured before the transmission of this message is requested.

The transmission of any number of Message Objects may be requested at the same time. Message objects are transmitted subsequently according to their internal priority. Messages may be updated or set to not valid any time, even when their requested transmission is still pending. The old data will be discarded when a message is updated before its pending transmission has started.

Depending on the configuration of the Message Object, the transmission of a message may be requested autonomously by the reception of a remote frame with a matching identifier.

#### **Disabled Automatic Retransmission**

In accordance with the CAN Specification (see ISO11898, 6.3.3 Recovery Management), the C\_CAN provides means for automatic retransmission of frames that have lost arbitration or have been disturbed by errors during transmission. The frame transmission service will not be confirmed to the user before the transmission is successfully completed. This means that, by default, automatic retransmission is enabled. It can be disabled to enable the C\_CAN to work within a Time Triggered CAN (TTCAN, see ISO11898-1) environment.

The Disabled Automatic Retransmission mode is enabled by setting the Disable Automatic Retransmission (DAR bit (CAN\_CON[5])) to one. In this operation mode, the programmer has to consider the different behavior of bits TxRqst (CAN\_IFn\_MCON[8]) and NewDat (CAN\_IFn\_MCON[15]) of the Message Buffers:

- When a transmission starts, bit TxRqst of the respective Message Buffer is cleared, while bit NewDat remains set.
- When the transmission completed successfully, bit NewDat is cleared.
- When a transmission fails (lost arbitration or error), bit NewDat remains set.
- To restart the transmission, the software should set the bit TxRqst again.

#### **6.27.6 Test Mode**

Test Mode is entered by setting the Test bit (CAN\_CON[7]). In Test Mode, bits Tx1 (CAN\_TEST[6]), Tx0 (CAN\_TEST[5]), LBack (CAN\_TEST[4]), Silent (CAN\_TEST[3]) and Basic (CAN\_TEST[2]) are writeable. Bit Rx (CAN\_TEST[7]) monitors the state of the CAN\_RX pin and therefore is only readable. All Test Register functions are disabled when the Test bit is cleared.

##### **6.27.6.1 Silent Mode**

The CAN Core can be set in Silent Mode by programming the Silent bit (CAN\_TEST[3]) to one. In Silent Mode, the C\_CAN is able to receive valid data frames and valid remote frames, but it sends only recessive bits on the CAN bus and it cannot start a transmission. If the CAN Core is required to send a dominant bit (ACK bit, Error Frames), the bit is rerouted internally so that the CAN Core monitors this dominant bit, although the CAN bus may remain in recessive state. The Silent Mode can be used to analyze the traffic on a CAN bus without affecting it by the transmission of dominant bits. Figure 6.27-2 CAN Core in Silent Mode shows the connection of signals CAN\_TX and CAN\_RX to the

CAN Core in Silent Mode.



Figure 6.27-2 CAN Core in Silent Mode

#### 6.27.6.2 Loop Back Mode

The CAN Core can be set in Loop Back Mode by programming the Test Register bit LBack (CAN\_TEST[4]) to one. In Loop Back Mode, the CAN Core treats its own transmitted messages as received messages and stores them in a Receive Buffer (if they pass acceptance filtering). Figure 6.27-3 shows the connection of signals, CAN\_TX and CAN\_RX, to the CAN Core in Loop Back Mode.



Figure 6.27-3 CAN Core in Loop Back Mode

This mode is provided for self-test functions. To be independent from external stimulation, the CAN Core ignores acknowledge errors (recessive bit sampled in the acknowledge slot of a data/ remote frame) in Loop Back Mode. In this mode, the CAN Core performs an internal feedback from its Tx output to its Rx input. The actual value of the CAN\_RX input pin is disregarded by the CAN Core. The transmitted messages can be monitored on the CAN\_TX pin.

#### 6.27.6.3 Loop Back Combined with Silent Mode

It is also possible to combine Loop Back Mode and Silent Mode by programming bits LBack (CAN\_TEST[4]) and Silent (CAN\_TEST[3]) to one at the same time. This mode can be used for a "Hot Selftest", which means that C\_CAN can be tested without affecting a running CAN system connected to the CAN\_TX and CAN\_RX pins. In this mode, the CAN\_RX pin is disconnected from the CAN Core and the CAN\_TX pin is held recessive. Figure 6.27-4 shows the connection of signals CAN\_TX and CAN\_RX to the CAN Core in case of the combination of Loop Back Mode with Silent Mode.



Figure 6.27-4 CAN Core in Loop Back Mode Combined with Silent Mode

#### 6.27.6.4 Basic Mode

The CAN Core can be set in Basic Mode by programming the Basic bit (CAN\_TEST[2]) to one. In this mode, the C\_CAN runs without the Message RAM.

The IF1 Registers are used as Transmit Buffer. The transmission of the contents of the IF1 Registers is requested by writing the Busy bit (CAN\_IFn\_CREQ[15]) of the IF1 Command Request Register to one. The IF1 Registers are locked while the Busy bit is set. The Busy bit indicates that the transmission is pending.

As soon the CAN bus is idle, the IF1 Registers are loaded into the shift register of the CAN Core and the transmission is started. When the transmission has been completed, the Busy bit is reset and the locked IF1 Registers are released.

A pending transmission can be aborted at any time by resetting the Busy bit in the IF1 Command Request Register while the IF1 Registers are locked. If the software has reset the Busy bit, a possible retransmission in case of lost arbitration or in case of an error is disabled.

The IF2 Registers are used as a Receive Buffer. After the reception of a message the contents of the shift register is stored into the IF2 Registers, without any acceptance filtering.

Additionally, the actual contents of the shift register can be monitored during the message transfer. Each time a read Message Object is initiated by writing the Busy bit of the IF2 Command Request Register to one, the contents of the shift register are stored into the IF2 Registers.

In Basic Mode, the evaluation of all Message Object related control and status bits and the control bits of the IFn Command Mask Registers are turned off. The message number of the Command request registers is not evaluated. The NewDat (CAN\_IFn\_MCON[15]) and MsgLst (CAN\_IFn\_MCON[14]) bits retain their function, DLC3-0 indicates the received DLC (CAN\_IFn\_MCON[3:0]), and the other control bits are read as '0'.

#### 6.27.6.5 Software Control of CAN\_TX Pin

Four output functions are available for the CAN transmit pin, CAN\_TX. In addition to its default function (serial data output), the CAN transmit pin can drive the CAN Sample Point signal to monitor CAN\_Core's bit timing and it can drive constant dominant or recessive values. The latter two functions, combined with the readable CAN receive pin CAN\_RX, can be used to check the physical layer of the CAN bus.

The output mode for the CAN\_TX pin is selected by programming the Tx1 (CAN\_TEST[6]) and Tx0 (CAN\_TEST[5]) bits.

The three test functions of the CAN\_TX pin interfere with all CAN protocol functions. CAN\_TX must be left in its default function when CAN message transfer or any of the test modes (Loop Back Mode, Silent Mode or Basic Mode) are selected.

## 6.27.7 CAN Communications

### 6.27.7.1 Managing Message Objects

The configuration of the Message Objects in the Message RAM (with the exception of the bits MsgVal, NewDat, IntPnd and TxRqst) will not be affected by resetting the chip. All the Message Objects must be initialized by the application software or they must be “not valid” (MsgVal bit = ‘0’) and the bit timing must be configured before the application software clears the Init bit (CAN\_CON[0]).

The configuration of a Message Object is done by programming Mask, Arbitration, Control and Data fields of one of the two interface registers to the desired values. By writing to the corresponding IFn Command Request Register, the IFn Message Buffer Registers are loaded into the addressed Message Object in the Message RAM.

When the Init bit is cleared, the CAN Protocol Controller state machine of the CAN\_Core and the state machine of the Message Handler control the internal data flow of the C\_CAN. Received messages that pass the acceptance filtering are stored into the Message RAM, messages with pending transmission request are loaded into the CAN\_Core’s Shift Register and are transmitted through the CAN bus.

The application software reads received messages and updates messages to be transmitted through the IFn Interface Registers. Depending on the configuration, the application software is interrupted on certain CAN message and CAN error events.

### 6.27.7.2 Message Handler State Machine

The Message Handler controls the data transfer between the Rx/Tx Shift Register of the CAN Core, the Message RAM and the IFn Registers.

The Message Handler FSM controls the following functions:

- Data Transfer from IFn Registers to the Message RAM
- Data Transfer from Message RAM to the IFn Registers
- Data Transfer from Shift Register to the Message RAM
- Data Transfer from Message RAM to Shift Register
- Data Transfer from Shift Register to the Acceptance Filtering unit
- Scanning of Message RAM for a matching Message Object
- Handling of TxRqst flags
- Handling of interrupts.

### 6.27.7.3 Data Transfer from/to Message RAM

When the application software initiates a data transfer between the IFn Registers and Message RAM, the Message Handler sets the Busy bit (CAN\_IFn\_CREQ[15]) to ‘1’. After the transfer has completed, the Busy bit is again cleared (see Figure 6.27-5).

The respective Command Mask Register specifies whether a complete Message Object or only parts of it will be transferred. Due to the structure of the Message RAM, it is not possible to write single bits/bytes of one Message Object. It is always necessary to write a complete Message Object into the Message RAM. Therefore, the data transfer from the IFn Registers to the Message RAM requires a read-modify-write cycle. First, those parts of the Message Object that are not to be changed are read from the Message RAM and then the complete contents of the Message Buffer Registers are written into the Message Object.



Figure 6.27-5 Data transfer between IFn Registers and Message

After a partial write of a Message Object, the Message Buffer Registers that are not selected in the Command Mask Register will set the actual contents of the selected Message Object.

After a partial read of a Message Object, the Message Buffer Registers that are not selected in the Command Mask Register will be left unchanged.

#### 6.27.7.4 Message Transmission

If the shift register of the CAN Core cell is ready for loading and if there is no data transfer between the IFn Registers and Message RAM, the MsgVal bit (CAN\_IFn\_ARB2[15]) and TxRqst bits (CAN\_TXREQ1/2) are evaluated. The valid Message Object with the highest priority pending transmission request is loaded into the shift register by the Message Handler and the transmission is started. The NewDat (CAN\_IFn\_MCON[15]) bit of the Message Object is reset.

After a successful transmission and also if no new data was written to the Message Object (NewDat = '0') since the start of the transmission, the TxRqst bit of the Message Control register (CAN\_IFn\_MCON[8]) will be reset. If TxE bit (CAN\_IFn\_MCON[11]) is set, IntPnd bit (CAN\_IFn\_MCON[13]) of the Interrupt Identifier register will be set after a successful transmission. If the C\_CAN has lost the arbitration or if an error occurred during the transmission, the message will be retransmitted as soon as the CAN bus is free again. Meanwhile, if the transmission of a message with higher priority has been requested, the messages will be transmitted in the order of their priority.

#### 6.27.7.5 Acceptance Filtering of Received Messages

When the arbitration and control field (Identifier + IDE + RTR + DLC) of an incoming message is completely shifted into the Rx/Tx Shift Register of the CAN Core, the Message Handler FSM starts the

scanning of the Message RAM for a matching valid Message Object.

To scan the Message RAM for a matching Message Object, the Acceptance Filtering unit is loaded with the arbitration bits from the CAN Core shift register. The arbitration and mask fields (including MsgVal (CAN\_IFn\_ARB2[15]), UMask (CAN\_IFn\_MCON[12]), NewDat (CAN\_IFn\_MCON[15]) and EoB (CAN\_IFn\_MCON[7])) of Message Object 1 are then loaded into the Acceptance Filtering unit and compared with the arbitration field from the shift register. This is repeated with each following Message Object until a matching Message Object is found or until the end of the Message RAM is reached.

If a match occurs, the scan is stopped and the Message Handler FSM proceeds depending on the type of frame (Data Frame or Remote Frame) received.

#### **Reception of Data Frame**

The Message Handler FSM stores the message from the CAN Core shift register into the respective Message Object in the Message RAM. Not only the data bytes, but all arbitration bits and the Data Length Code are stored into the corresponding Message Object. This is done to keep the data bytes connected with the identifier even if arbitration mask registers are used.

The NewDat bit (CAN\_IFn\_MCON[15]) is set to indicate that new data (not yet seen by the software) has been received. The application software should reset NewDat bit when the Message Object has been read. If at the time of reception, the NewDat bit was already set, MsgLst (CAN\_IFn\_MCON[14]) is set to indicate that the previous data (supposedly not seen by the software) is lost. If the RxIE bit (CAN\_IFn\_MCON[10]) is set, the IntPnd bit (CAN\_IFn\_MCON[13]) is set, causing the Interrupt Register to point to this Message Object.

The TxRqst bit (CAN\_IFn\_MCON[8]) of this Message Object is reset to prevent the transmission of a Remote Frame, while the requested Data Frame has just been received.

#### **Reception of Remote Frame**

When a Remote Frame is received, three different configurations of the matching Message Object have to be considered:

1. Dir (CAN\_IFn\_ARB2[13]) = '1' (direction = transmit), RmtEn (CAN\_IFn\_MCON[9]) = '1' and UMask (CAN\_IFn\_MCON[12]) = '1' or '0'
2. At the reception of a matching Remote Frame, the TxRqst bit of this Message Object is set. The rest of the Message Object remains unchanged.
3. Dir = '1' (direction = transmit), RmtEn = '0' and UMask = '0'
4. At the reception of a matching Remote Frame, the TxRqst bit of this Message Object remains unchanged; the Remote Frame is ignored.
5. Dir = '1' (direction = transmit), RmtEn = '0' and UMask = '1'
6. At the reception of a matching Remote Frame, the TxRqst bit of this Message Object is reset. The arbitration and control field (Identifier + IDE + RTR + DLC) from the shift register is stored in the Message Object of the Message RAM and the NewDat bit (CAN\_IFn\_MCON[15]) of this Message Object is set. The data field of the Message Object remains unchanged; the Remote Frame is treated similar to a received Data Frame.

##### **6.27.7.6 Receive/Transmit Priority**

The receive/transmit priority for the Message Objects is attached to the message number. Message Object 1 has the highest priority, while Message Object 32 has the lowest priority. If more than one transmission request is pending, they are serviced due to the priority of the corresponding Message Object.

##### **6.27.7.7 Configuring a Transmit Object**

Table 6.27-1 shows how a Transmit Object should be initialized.

| Ms | Arb   | Data  | Mask  | EoB | Dir | NewDat | MsgLst | RxIE | TxIE  | IntPnd | RmtEn | TxRqst |
|----|-------|-------|-------|-----|-----|--------|--------|------|-------|--------|-------|--------|
| 1  | appl. | appl. | appl. | 1   | 1   | 0      | 0      | 0    | appl. | 0      | appl. | 0      |

Table 6.27-1 Initialization of a Transmit Object

**Note:** appl. = application software.

The Arbitration Register values (ID28-0 (CAN\_IFn\_ARB1/2) and Xtd bit (CAN\_IFn\_ARB2[14])) are provided by the application. They define the identifier and type of the outgoing message. If an 11-bit Identifier ("Standard Frame") is used, it is programmed to ID28 - ID18. The ID17 - ID0 can then be disregarded.

If the TxIE bit (CAN\_IFn\_MCON[11]) is set, the IntPnd bit (CAN\_IFn\_MCON[13]) will be set after a successful transmission of the Message Object.

If the RmtEn bit (CAN\_IFn\_MCON[9]) is set, a matching received Remote Frame will cause the TxRqst bit (CAN\_IFn\_MCON[8]) to be set; the Remote Frame will autonomously be answered by a Data Frame.

The Data Register values (DLC3-0 (CAN\_IFn\_MCON[3:0]), Data(0)-(7)) are provided by the application, TxRqst and RmtEn may not be set before the data is valid.

The Mask Registers (Msk28-0, UMask, MXtd and MDir bits) may be used (UMask (CAN\_IFn\_MCON[12]) = '1') to allow groups of Remote Frames with similar identifiers to set the TxRqst bit. The Dir bit (CAN\_IFn\_ARB2[13]) should not be masked.

#### 6.27.7.8 Updating a Transmit Object

The software may update the data bytes of a Transmit Object any time through the IFn Interface registers, neither MsgVal bit (CAN\_IFn\_ARB2[15]) nor TxRqst (CAN\_IFn\_MCON[8]) have to be reset before the update.

Even if only a part of the data bytes are to be updated, all four bytes of the corresponding IFn Data A Register or IFn Data B Register have to be valid before the contents of that register are transferred to the Message Object. Either the application software has to write all four bytes into the IFn Data Register or the Message Object is transferred to the IFn Data Register before the software writes the new data bytes.

When only the (eight) data bytes are updated, first 0x0087 is written to the Command Mask Register and then the number of the Message Object is written to the Command Request Register, concurrently updating the data bytes and setting TxRqst.

To prevent the reset of TxRqst at the end of a transmission that may already be in progress while the data is updated, NewDat (CAN\_IFn\_MCON[15]) has to be set together with TxRqst.

When NewDat is set together with TxRqst, NewDat will be reset as soon as the new transmission has started.

#### 6.27.7.9 Configuring a Receive Object

Table 6.27-2 shows how a Receive Object should be initialized.

| MsgVal | Arb   | Data  | Mask  | EoB | Dir | NewDat | MsgLst | RxIE  | TxIE | IntPnd | RmtEn | TxRqst |
|--------|-------|-------|-------|-----|-----|--------|--------|-------|------|--------|-------|--------|
| 1      | appl. | appl. | appl. | 1   | 0   | 0      | 0      | appl. | 0    | 0      | 0     | 0      |

Table 6.27-2 Initialization of a Receive Object

The Arbitration Registers values (ID28-0 (CAN\_IFn\_ARB1/2) and Xtd bit (CAN\_IFn\_ARB2[14])) are provided by the application. They define the identifier and type of accepted received messages. If an 11-bit Identifier ("Standard Frame") is used, it is programmed to ID28 - ID18. Then ID17 - ID0 can be disregarded. When a Data Frame with an 11-bit Identifier is received, ID17 - ID0 will be set to '0'.

If the RxIE bit (CAN\_IFn\_MCON[10]) is set, the IntPnd bit (CAN\_IFn\_MCON[13]) will be set when a received Data Frame is accepted and stored in the Message Object.

The Data Length Code (DLC3-0 (CAN\_IFn\_MCON[3:0])) is provided by the application. When the Message Handler stores a Data Frame in the Message Object, it will store the received Data Length Code and eight data bytes. If the Data Length Code is less than 8, the remaining bytes of the Message Object will be overwritten by unspecified values.

The Mask Registers (Msk28-0, UMask, MXtd and MDir bits) may be used (UMask (CAN\_IFn\_MCON[12]) = '1') to allow groups of Data Frames with similar identifiers to be accepted. The Dir bit (CAN\_IFn\_ARB2[13]) should not be masked in typical applications.

#### 6.27.7.10 Handling Received Messages

The application software may read a received message any time through the IFn Interface registers. The data consistency is guaranteed by the Message Handler state machine.

Typically, the software will write first 0x007F to the Command Mask Register and then the number of the Message Object to the Command Request Register. This combination will transfer the whole received message from the Message RAM into the Message Buffer Register. Additionally, the bits NewDat (CAN\_IFn\_MCON[15]) and IntPnd (CAN\_IFn\_MCON[13]) are cleared in the Message RAM (not in the Message Buffer).

If the Message Object uses masks for acceptance filtering, the arbitration bits show which of the matching messages have been received.

The actual value of NewDat shows whether a new message has been received since the last time this Message Object was read. The actual value of MsgLst (CAN\_IFn\_MCON[14]) shows whether more than one message has been received since the last time this Message Object was read. MsgLst will not be automatically reset.

By means of a Remote Frame, the software may request another CAN node to provide new data for a receive object. Setting the TxRqst bit (CAN\_IFn\_MCON[8]) of a receive object will cause the transmission of a Remote Frame with the receive object's identifier. This Remote Frame triggers the other CAN node to start the transmission of the matching Data Frame. If the matching Data Frame is received before the Remote Frame could be transmitted, the TxRqst bit is automatically reset.

#### 6.27.7.11 Configuring a FIFO Buffer

With the exception of the EoB bit (CAN\_IFn\_MCON[7]), the configuration of Receive Objects belonging to a FIFO Buffer is the same as the configuration of a (single) Receive Object, see Section 6.5.7.9: Configuring a Receive Object.

To concatenate two or more Message Objects into a FIFO Buffer, the identifiers and masks (if used) of these Message Objects have to be programmed to matching values. Due to the implicit priority of the Message Objects, the Message Object with the lowest number will be the first Message Object of the FIFO Buffer. The EoB bit of all Message Objects of a FIFO Buffer except the last have to be programmed to zero. The EoB bit of the last Message Object of a FIFO Buffer is set to one, configuring it as the End of the Block.

#### 6.27.7.12 Receiving Messages with FIFO Buffers

Received messages with identifiers matching to a FIFO Buffer are stored into a Message Object of this FIFO Buffer starting with the Message Object with the lowest message number.

When a message is stored into a Message Object of a FIFO Buffer, the NewDat bit (CAN\_IFn\_MCON[15]) of this Message Object is set. By setting NewDat while EoB

(CAN\_IFn\_MCON[7]) is zero, the Message Object is locked for further write access by the Message Handler until the application software has written the NewDat bit back to zero.

Messages are stored into a FIFO Buffer until the last Message Object of this FIFO Buffer is reached. If none of the preceding Message Objects is released by writing NewDat to zero, all further messages for this FIFO Buffer will be written into the last Message Object of the FIFO Buffer and therefore overwrite the previous messages.

#### 6.27.7.13 Reading from a FIFO Buffer

When the application software transfers the contents of a Message Object to the IFn Message Buffer register by writing its number to the IFn Command Request Register, the corresponding Command Mask Register should be programmed in such a way that bits NewDat (CAN\_IFn\_MCON[15]) and IntPnd (CAN\_IFn\_MCON[13]) are reset to zero (TxRqst/NewDat (CAN\_IFn\_CMASK[2]) = '1' and ClrIntPnd (CAN\_IFn\_CMASK[3]) = '1'). The values of these bits in the Message Control Register always reflect the status before resetting the bits.

To assure the correct function of a FIFO Buffer, the application software should read the Message Objects starting at the FIFO Object with the lowest message number.

Figure 6.27-6 shows how a set of Message Objects which are concatenated to a FIFO Buffer can be handled by the application software.



Figure 6.27-6 Application Software Handling of a FIFO Buffer

#### 6.27.7.14 Handling Interrupts

If several interrupts are pending, the CAN Interrupt Register will point to the pending interrupt with the highest priority, disregarding their chronological order. An interrupt remains pending until the application software has cleared it.

The Status Interrupt has the highest priority. Among the message interrupts, interrupt priority of the Message Object decreases with increasing message number.

A message interrupt is cleared by clearing the IntPnd bit (CAN\_IFn\_MCON[13]) of the Message Object. The Status Interrupt is cleared by reading the Status Register.

The interrupt identifier, IntId, in the Interrupt Register, indicates the cause of the interrupt. When no interrupt is pending, the register will hold the value zero. If the value of the Interrupt Register is different from zero, then there is an interrupt pending and, if IE (CAN\_CON[1]) is set, the CAN\_INT interrupt signal is active. The interrupt remains active until the Interrupt Register is back to value zero (the cause of the interrupt is reset) or until IE is reset.

The value 0x8000 indicates that an interrupt is pending because the CAN Core has updated (not necessarily changed) the Status Register (Error Interrupt or Status Interrupt). This interrupt has the highest priority. The application software can update (reset) the status bits RxOk (CAN\_STATUS[4]), TxOk (CAN\_STATUS[3]) and LEC (CAN\_STATUS[2:0]), but a write access of the software to the Status Register can never generate or reset an interrupt.

All other values indicate that the source of the interrupt is one of the Message Objects. IntId points to the pending message interrupt with the highest interrupt priority.

The application software controls whether a change of the Status Register may cause an interrupt (bits EIE (CAN\_CON[3]) and SIE (CAN\_CON[2])) and whether the interrupt line becomes active when the Interrupt Register is different from zero (bit IE in the CAN Control Register). The Interrupt Register will be updated even when IE is reset.

The application software has two possibilities to follow the source of a message interrupt. First, it can follow the IntId in the Interrupt Register and second it can poll the Interrupt Pending Register.

An interrupt service routine that is reading the message that is the source of the interrupt may read the message and reset the Message Object's IntPnd at the same time (bit ClrIntPnd (CAN\_IFn\_CMASK[3])). When IntPnd is cleared, the Interrupt Register will point to the next Message Object with a pending interrupt.

#### 6.27.7.15 Configuring the Bit Timing

Even if minor errors in the configuration of the CAN bit timing do not result in immediate failure, the performance of a CAN network can be reduced significantly.

In many cases, the CAN bit synchronization will amend a faulty configuration of the CAN bit timing to such a degree that only occasionally an error frame is generated. However, in the case of arbitration, when two or more CAN nodes simultaneously try to transmit a frame, a misplaced sample point may cause one of the transmitters to become error passive.

The analysis of such sporadic errors requires a detailed knowledge of the CAN bit synchronization inside a CAN node and interaction of the CAN nodes on the CAN bus.

#### 6.27.7.16 Bit Time and Bit Rate

CAN supports bit rates in the range of lower than 1 Kbit/s up to 1000 Kbit/s. Each member of the CAN network has its own clock generator, usually a quartz oscillator. The timing parameter of the bit time (i.e. the reciprocal of the bit rate) can be configured individually for each CAN node, creating a common bit rate even though the oscillator periods of the CAN nodes (fosc) may be different.

The frequencies of these oscillators are not absolutely stable, small variations are caused by changes in temperature or voltage and by deteriorating components. As long as the variations remain inside a specific oscillator tolerance range (df), the CAN nodes are able to compensate for the different bit rates by re-synchronizing to the bit stream.

According to the CAN specification, the bit time is divided into four segments (see Figure 6.27-7). The Synchronization Segment, the Propagation Time Segment, the Phase Buffer Segment 1 and the Phase Buffer Segment 2. Each segment consists of a specific, programmable number of time quanta (Table 6.27-3). The length of the time quantum (tq), which is the basic time unit of the bit time, is defined by the CAN controller's APB clock fAPB and the BRP bit (CAN\_BTME[5:0]) : tq = BRP / fAPB.

The Synchronization Segment, Sync\_Seg, is that part of the bit time where edges of the CAN bus level are expected to occur. The distance between an edge that occurs outside of Sync\_Seg, and the Sync\_Seg is called the phase error of that edge. The Propagation Time Segment, Prop\_Seg, is intended to compensate for the physical delay time within the CAN network. The Phase Buffer Segments Phase\_Seg1 and Phase\_Seg2 surround the Sample Point. The (Re-)Synchronization Jump Width (SJW) defines how far a re-synchronization may move the Sample Point inside the limits defined by the Phase Buffer Segments to compensate for edge phase errors.



Figure 6.27-7 Bit Timing

| Parameter                                                                         | Range        | Remark                                                   |
|-----------------------------------------------------------------------------------|--------------|----------------------------------------------------------|
| BRP                                                                               | [1..32]      | Defines the length of the time quantum $t_q$             |
| Sync_Seg                                                                          | $1 t_q$      | Fixed length, synchronization of bus input to APB clock  |
| Prop_Seg                                                                          | [1..8] $t_q$ | Compensates for the physical delay time                  |
| Phase_Seg1                                                                        | [1..8] $t_q$ | Which may be lengthened temporarily by synchronization   |
| Phase_Seg2                                                                        | [1..8] $t_q$ | Which may be shortened temporarily by synchronization    |
| SJW                                                                               | [1..4] $t_q$ | Which may not be longer than either Phase Buffer Segment |
| This table describes the minimum programmable ranges required by the CAN protocol |              |                                                          |

Table 6.27-3 CAN Bit Time Parameters

A given bit rate may be met by different bit time configurations, but for the proper function of the CAN network the physical delay time and the oscillator's tolerance range have to be considered.

#### 6.27.7.17 Propagation Time Segment

This part of the bit time is used to compensate physical delay time within the network. These delay time consist of the signal propagation time on the bus and the internal delay time of the CAN nodes.

Any CAN node synchronized to the bit stream on the CAN bus will be out of phase with the transmitter of that bit stream, caused by the signal propagation time between the two nodes. The CAN protocol's non-destructive bitwise arbitration and the dominant acknowledge bit provided by receivers of CAN messages requires that a CAN node transmitting a bit stream must also be able to receive dominant bits transmitted by other CAN nodes that are synchronized to that bit stream. The example in Figure 6.27-8 shows the phase shift and propagation time between two CAN nodes.



Figure 6.27-8 Propagation Time Segment

In this example, both nodes A and B are transmitters, performing an arbitration for the CAN bus. Node A has sent its Start of Frame bit less than one bit time earlier than node B, therefore node B has synchronized itself to the received edge from recessive to dominant. Since node B has received this edge delay ( $A_{to}B$ ) after it has been transmitted, B's bit timing segments are shifted with respect to A. Node B sends an identifier with higher priority and so it will win the arbitration at a specific identifier bit when it transmits a dominant bit while node A transmits a recessive bit. The dominant bit transmitted by node B will arrive at node A after the delay ( $B_{to}A$ ).

Due to oscillator tolerances, the actual position of node A's Sample Point can be anywhere inside the nominal range of node A's Phase Buffer Segments, so the bit transmitted by node B must arrive at node A before the start of Phase\_Seg1. This condition defines the length of Prop\_Seg.

If the edge from recessive to dominant transmitted by node B arrives at node A after the start of Phase\_Seg1, it can happen that node A samples a recessive bit instead of a dominant bit, resulting in a bit error and the destruction of the current frame by an error flag.

The error occurs only when two nodes arbitrate for the CAN bus that have oscillators of opposite ends of the tolerance range and that are separated by a long bus line. This is an example of a minor error in the bit timing configuration (Prop\_Seg is too short) that causes sporadic bus errors.

Some CAN implementations provide an optional 3 Sample Mode but the C\_CAN does not. In this mode, the CAN bus input signal passes a digital low-pass filter, using three samples and a majority logic to determine the valid bit value. This results in an additional input delay of 1 tq, requiring a longer Prop\_Seg.

#### 6.27.7.18 Phase Buffer Segments and Synchronization

The Phase Buffer Segments (Phase\_Seg1 and Phase\_Seg2) and the Synchronization Jump Width (SJW) are used to compensate for the oscillator tolerance. The Phase Buffer Segments may be lengthened or shortened by synchronization.

Synchronizations occur on edges from recessive to dominant, their purpose is to control the distance between edges and Sample Points.

Edges are detected by sampling the actual bus level in each time quantum and comparing it with the bus level at the previous Sample Point. A synchronization may be done only if a recessive bit was sampled at the previous Sample Point and if the bus level at the actual time quantum is dominant.

An edge is synchronous if it occurs inside of Sync\_Seg, otherwise the distance between edge and the end of Sync\_Seg is the edge phase error, measured in time quanta. If the edge occurs before Sync\_Seg, the phase error is negative, else it is positive.

Two types of synchronization exist, Hard Synchronization and Re-synchronization.

A Hard Synchronization is done once at the start of a frame and inside a frame only when Re-synchronizations occur.

### Hard Synchronization

After a hard synchronization, the bit time is restarted with the end of Sync\_Seg, regardless of the edge phase error. Thus hard synchronization forces the edge, which has caused the hard synchronization to lie within the synchronization segment of the restarted bit time.

### Bit Re-synchronization

Re-synchronization leads to a shortening or lengthening of the bit time such that the position of the sample point is shifted with regard to the edge.

When the phase error of the edge which causes Re-synchronization is positive, Phase\_Seg1 is lengthened. If the magnitude of the phase error is less than SJW, Phase\_Seg1 is lengthened by the magnitude of the phase error, else it is lengthened by SJW.

When the phase error of the edge, which causes Re-synchronization is negative, Phase\_Seg2 is shortened. If the magnitude of the phase error is less than SJW, Phase\_Seg2 is shortened by the magnitude of the phase error, else it is shortened by SJW.

When the magnitude of the phase error of the edge is less than or equal to the programmed value of SJW, the results of Hard Synchronization and Re-synchronization are the same. If the magnitude of the phase error is larger than SJW, the Re-synchronization cannot compensate the phase error completely, an error (phase error - SJW) remains.

Only one synchronization may be done between two Sample Points. The Synchronizations maintain a minimum distance between edges and Sample Points, giving the bus level time to stabilize and filtering out spikes that are shorter than (Prop\_Seg + Phase\_Seg1).

Apart from noise spikes, most synchronizations are caused by arbitration. All nodes synchronize "hard" on the edge transmitted by the "leading" transceiver that started transmitting first, but due to propagation delay time, they cannot become ideally synchronized. The "leading" transmitter does not necessarily win the arbitration, therefore the receivers have to synchronize themselves to different transmitters that subsequently "take the lead" and that are differently synchronized to the previously "leading" transmitter. The same happens at the acknowledge field, where the transmitter and some of the receivers will have to synchronize to that receiver that "takes the lead" in the transmission of the dominant acknowledge bit.

Synchronizations after the end of the arbitration will be caused by oscillator tolerance, when the differences in the oscillator's clock periods of transmitter and receivers sum up during the time between synchronizations (at most ten bits). These summarized differences may not be longer than the SJW, limiting the oscillator's tolerance range.

The examples in Figure 6.27-9 show how the Phase Buffer Segments are used to compensate for phase errors. There are three drawings of each two consecutive bit timings. The upper drawing shows the synchronization on a "late" edge, the lower drawing shows the synchronization on an "early" edge, and the middle drawing is the reference without synchronization.



Figure 6.27-9 Synchronization on “late” and “early” Edges

In the first example an edge from recessive to dominant occurs at the end of Prop\_Seg. The edge is “late” since it occurs after the Sync\_Seg. Reacting to the “late” edge, Phase\_Seg1 is lengthened so that the distance from the edge to the Sample Point is the same as it would have been from the Sync\_Seg to the Sample Point if no edge had occurred. The phase error of this “late” edge is less than SJW, so it is fully compensated and the edge from dominant to recessive at the end of the bit, which is one nominal bit time long, occurs in the Sync\_Seg.

In the second example an edge from recessive to dominant occurs during Phase\_Seg2. The edge is “early” since it occurs before a Sync\_Seg. Reacting to the “early” edge, Phase\_Seg2 is shortened and Sync\_Seg is omitted, so that the distance from the edge to the Sample Point is the same as it would have been from an Sync\_Seg to the Sample Point if no edge had occurred. As in the previous example, the magnitude of this “early” edge’s phase error is less than SJW, so it is fully compensated.

The Phase Buffer Segments are lengthened or shortened temporarily only; at the next bit time, the segments return to their nominal programmed values.

In these examples, the bit timing is seen from the point of view of the CAN implementation’s state machine, where the bit time starts and ends at the Sample Points. The state machine omits Sync\_Seg when synchronising on an “early” edge because it cannot subsequently redefine that time quantum of Phase\_Seg2 where the edge occurs to be the Sync\_Seg.

The examples in Figure 6.27-11 show how short dominant noise spikes are filtered by synchronisations. In both examples the spike starts at the end of Prop\_Seg and has the length of (Prop\_Seg + Phase\_Seg1).

In the first example, the Synchronization Jump Width is greater than or equal to the phase error of the spike’s edge from recessive to dominant. Therefore the Sample Point is shifted after the end of the spike; a recessive bus level is sampled.

In the second example, SJW is shorter than the phase error, so the Sample Point cannot be shifted far enough; the dominant spike is sampled as actual bus level.



Figure 6.27-10 Filtering of Short Dominant Spikes

#### 6.27.7.19 Oscillator Tolerance Range

The oscillator tolerance range was increased when the CAN protocol was developed from version 1.1 to version 1.2 (version 1.0 was never implemented in silicon). The option to synchronize on edges from dominant to recessive became obsolete, only edges from recessive to dominant are considered for synchronization. The protocol update to version 2.0 (A and B) had no influence on the oscillator tolerance.

The tolerance range  $df$  for an oscillator frequency  $f_{osc}$  around the nominal frequency  $f_{nom}$  is:

$$(1 - df) \cdot f_{nom} \leq f_{osc} \leq (1 + df) \cdot f_{nom}$$

It depends on the proportions of Phase\_Seg1, Phase\_Seg2, SJW and the bit time. The maximum tolerance  $df$  is defined by two conditions (both shall be met):

$$I: df \leq \frac{\min(\text{Phase\_Seg1}, \text{Phase\_Seg2})}{2 * (13 * \text{bit\_time} - \text{Phase\_Seg2})}$$

$$II: df \leq \frac{\text{SJW}}{20 * \text{bit\_time}}$$

**Note:** These conditions base on the APB clock =  $f_{osc}$ .

It has to be considered that SJW may not be larger than the smaller of the Phase Buffer Segments and that the Propagation Time Segment limits that part of the bit time that may be used for the Phase Buffer Segments.

The combination Prop\_Seg = 1 and Phase\_Seg1 = Phase\_Seg2 = SJW = 4 allows the largest possible oscillator tolerance of 1.58%. This combination with a Propagation Time Segment of only 10% of the bit time is not suitable for short bit times; it can be used for bit rates of up to 125 Kbit/s (bit time = 8us) with a bus length of 40 m.

#### 6.27.7.20 Configuring the CAN Protocol Controller

In most CAN implementations and also in the C\_CAN, the bit timing configuration is programmed in two register bytes. The sum of Prop\_Seg and Phase\_Seg1 (as TSEG1 (CAN\_BTIME[11:8])) is combined with Phase\_Seg2 (as TSEG2 (CAN\_BTIME[14:12])) in one byte, SJW (CAN\_BTIME[7:6]) and BRP (CAN\_BTIME[5:0]) are combined in the other byte.

In these bit timing registers, the four components TSEG1, TSEG2, SJW and BRP have to be

programmed to a numerical value that is one less than its functional value. Therefore, instead of values in the range of [1..n], values in the range of [0..n-1] are programmed. That way, e.g. SJW (functional range of [1..4]) is represented by only two bits.

Therefore the length of the bit time is (programmed values)  $[TSEG1 + TSEG2 + 3] tq$  or (functional values)  $[Sync\_Seg + Prop\_Seg + Phase\_Seg1 + Phase\_Seg2] tq$ .



Figure 6.27-11 Structure of the CAN Core's CAN Protocol Controller

The data in the bit timing registers is the configuration input of the CAN protocol controller. The Baud Rate Prescaler (configured by BRP) defines the length of the time quantum, the basic time unit of the bit time; the Bit Timing Logic (configured by TSEG1, TSEG2 and SJW) defines the number of time quanta in the bit time.

The processing of the bit time, the calculation of the position of the Sample Point, and occasional synchronizations are controlled by the BTL (Bit Timing Logic) state machine, which is evaluated once each time quantum. The rest of the CAN protocol controller, the BSP (Bit Stream Processor) state machine is evaluated once each bit time, at the Sample Point.

The Shift Register sends the messages serially and parallelizes received messages. Its loading and shifting is controlled by the BSP.

The BSP translates messages into frames and vice versa. It generates and discards the enclosing fixed format bits, inserts and extracts stuff bits, calculates and checks the CRC code, performs the error management, and decides which type of synchronization is to be used. It is evaluated at the Sample Point and processes the sampled bus input bit. The time that is needed to calculate the next bit to be sent after the Sample point (e.g. data bit, CRC (Cyclic Redundancy Check) bit, stuff bit, error flag or idle) is called the Information Processing Time (IPT).

The IPT is application specific but may not be longer than 2  $tq$ ; the IPT for the C\_CAN is 0  $tq$ . Its length is the lower limit of the programmed length of Phase\_Seg2. In case of a synchronization, Phase\_Seg2 may be shortened to a value less than IPT, which does not affect bus timing.

#### 6.27.7.21 Calculating Bit Timing Parameters

Usually, the calculation of the bit timing configuration starts with a desired bit rate or bit time. The resulting bit time (1/bit rate) must be an integer multiple of the APB clock period.

The bit time may consist of 4 to 25 time quanta, the length of the time quantum tq is defined by the Baud Rate Prescaler with  $t_q = (\text{Baud Rate Prescaler})/\text{fapb\_clk}$ . Several combinations may lead to the desired bit time, allowing iterations of the following steps.

First part of the bit time to be defined is the Prop\_Seg. Its length depends on the delay time measured in the APB clock. A maximum bus length as well as a maximum node delay has to be defined for expandible CAN bus systems. The resulting time for Prop\_Seg is converted into time quanta (rounded up to the nearest integer multiple of tq).

The Sync\_Seg is 1 tq long (fixed), leaving (bit time – Prop\_Seg – 1) tq for the two Phase Buffer Segments. If the number of remaining tq is even, the Phase Buffer Segments have the same length, Phase\_Seg2 = Phase\_Seg1, else Phase\_Seg2 = Phase\_Seg1 + 1.

The minimum nominal length of Phase\_Seg2 has to be regarded as well. Phase\_Seg2 may not be shorter than the IPT of the CAN controller, which, depending on the actual implementation, is in the range of [0..2] tq.

The length of the Synchronization Jump Width is set to its maximum value, which is the minimum of 4 and Phase\_Seg1.

The oscillator tolerance range necessary for the resulting configuration is calculated by the formulas given in Section “Oscillator Tolerance Range”.

If more than one configuration is possible, that configuration allowing the highest oscillator tolerance range should be chosen.

CAN nodes with different system clocks require different configurations to come to the same bit rate. The calculation of the propagation time in the CAN network, based on the nodes with the longest delay time, is done once for the whole network.

The oscillator tolerance range of the CAN systems is limited by that node with the lowest tolerance range.

The calculation may shows that bus length or bit rate have to be decreased or that the stability of the oscillator frequency has to be increased in order to find a protocol compliant configuration of the CAN bit timing. The resulting configuration is written into the Bit Timing Register: (Phase\_Seg2-1) & (Phase\_Seg1+Prop\_Seg-1) & (SynchronisationJumpWidth-1) & (Prescaler-1)

### Example for Bit Timing at High Baud Rate

In this example, the frequency of APB\_CLK is 10 MHz, BRP (CAN\_BTIME[5:0]) is 0, and the bit rate is 1 MBit/s.

|                           |        |                                                                             |
|---------------------------|--------|-----------------------------------------------------------------------------|
| $t_q$                     | 100 ns | $= t_{\text{APB\_CLK}}$                                                     |
| delay of bus driver       | 50ns   |                                                                             |
| delay of receiver circuit | 30ns   |                                                                             |
| delay of bus line (40m)   | 220ns  |                                                                             |
| $t_{\text{Prop}}$         | 600ns  | $= 6 \cdot t_q$                                                             |
| $t_{\text{SJW}}$          | 100ns  | $= 1 \cdot t_q$                                                             |
| $t_{\text{TSeg1}}$        | 700ns  | $= t_{\text{Prop}} + t_{\text{SJW}}$                                        |
| $t_{\text{TSeg2}}$        | 200ns  | $= \text{Information Processing Time} + 1 \cdot t_q$                        |
| $t_{\text{Sync-Seg}}$     | 100ns  | $= 1 \cdot t_q$                                                             |
| bit time                  | 1000ns | $= t_{\text{Sync-Seg}} + t_{\text{TSeg1}} + t_{\text{TSeg2}}$               |
| tolerance for APB_CLK     | 0.39%  | $= \frac{\text{Min}(PB1, PB2)}{2 \times 13 \times (\text{bit time} - PB2)}$ |

$$= \frac{0.1\mu s}{2 \times 13 \times (1\mu s - 0.2\mu s)}$$

In this example, the concatenated bit time parameters are (2-1)<sub>3</sub> & (7-1)<sub>4</sub> & (1-1)<sub>2</sub> & (1-1)<sub>6</sub>, and the Bit Timing Register is programmed to 0x1600.

Note:

PB1/2: indicate the phase buffer segment 1/2

The subscript of (2-1)<sub>3</sub> indicates the number of bits in the corresponding bit of Bit Timing Register.

#### 6.27.7.22 CAN Interface Reset State

After the hardware reset, the C\_CAN registers hold the reset values which are given in the register description in 0.

Additionally the bus-off state is reset and the output CAN\_TX is set to recessive (HIGH). The value 0x0001 (Init = '1') in the CAN Control Register enables the software initialization. The C\_CAN does not influence the CAN bus until the application software resets the Init bit (CAN\_CON[0]) to '0'.

The data stored in the Message RAM is not affected by a hardware reset. After powered on, the contents of the Message RAM are undefined.

#### Example for Bit Timing at Low Baud Rate

In this example, the frequency of APB\_CLK is 2 MHz, BRP (CAN\_BTIME[5:0]) is 1, and the bit rate is 100 Kbit/s.

|                           |                                                         |                                                                   |
|---------------------------|---------------------------------------------------------|-------------------------------------------------------------------|
| $t_q$                     | 1                                                       | $\mu s = 2 \cdot t_{APB\_CLK}$                                    |
| delay of bus driver       | 200ns                                                   |                                                                   |
| delay of receiver circuit | 80ns                                                    |                                                                   |
| delay of bus line (40m)   | 220ns                                                   |                                                                   |
| $t_{Prop}$                | 1 $\mu s = 1 \cdot t_q$                                 |                                                                   |
| $t_{SJW}$                 | 4 $\mu s = 4 \cdot t_q$                                 |                                                                   |
| $t_{TSeg1}$               | 5 $\mu s = t_{Prop} + t_{SJW}$                          |                                                                   |
| $t_{TSeg2}$               | 4 $\mu s =$ Information Processing Time + 3 $\cdot t_q$ |                                                                   |
| $t_{Sync-Seg}$            | 1 $\mu s = 1 \cdot t_q$                                 |                                                                   |
| bit time                  | 10 $\mu s = t_{Sync-Seg} + t_{TSeg1} + t_{TSeg2}$       |                                                                   |
| tolerance for APB_CLK     | 1.58                                                    | $\% = \frac{Min(PB1, PB2)}{2 \times 13 \times (bit\ time - PB2)}$ |
|                           |                                                         | $= \frac{4\mu s}{2 \times (13 \times (10\mu s - 4\mu s))}$        |

In this example, the concatenated bit time parameters are (4-1)<sub>3</sub> & (5-1)<sub>4</sub> & (4-1)<sub>2</sub> & (2-1)<sub>6</sub>, and the Bit Timing Register is programmed to 0x34C1.

### 6.27.8 Register Map

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

| Register                        | Offset                         | R/W | Description                                         | Reset Value |
|---------------------------------|--------------------------------|-----|-----------------------------------------------------|-------------|
| <b>CAN Base Address:</b>        |                                |     |                                                     |             |
| <b>CAN_BA = 0x400A_0000</b>     |                                |     |                                                     |             |
| <b>CAN_CON</b>                  | CAN_BA+0x00                    | R/W | Control Register                                    | 0x0000_0001 |
| <b>CAN_STATUS</b>               | CAN_BA+0x04                    | R/W | Status Register                                     | 0x0000_0000 |
| <b>CAN_ERR</b>                  | CAN_BA+0x08                    | R   | Error Counter Register                              | 0x0000_0000 |
| <b>CAN_BTIME</b>                | CAN_BA+0x0C                    | R/W | Bit Timing Register                                 | 0x0000_2301 |
| <b>CAN_IIDR</b>                 | CAN_BA+0x10                    | R   | Interrupt Identifier Register                       | 0x0000_0000 |
| <b>CAN_TEST</b>                 | CAN_BA+0x14                    | R/W | Test Register (Register Map Note 1)                 | 0x0000_0080 |
| <b>CAN_BRPE</b>                 | CAN_BA+0x18                    | R/W | Baud Rate Prescaler Extension Register              | 0x0000_0000 |
| <b>CAN_IFn_CREQ<br/>n = 1,2</b> | CAN_BA+0x20 +<br>(0x60 *(n-1)) | R/W | IFn (Register Map Note 2) Command Request Registers | 0x0000_0001 |
| <b>CAN_IFn_CMASK<br/>n=1,2</b>  | CAN_BA+0x24 +<br>(0x60 *(n-1)) | R/W | IFn Command Mask Registers                          | 0x0000_0000 |
| <b>CAN_IFn_MASK1<br/>n=1,2</b>  | CAN_BA+0x28 +<br>(0x60 *(n-1)) | R/W | IFn Mask 1 Registers                                | 0x0000_FFFF |
| <b>CAN_IFn_MASK2<br/>n=1,2</b>  | CAN_BA+0x2C +<br>(0x60 *(n-1)) | R/W | IFn Mask 2 Registers                                | 0x0000_FFFF |
| <b>CAN_IFn_ARB1<br/>n=1,2</b>   | CAN_BA+0x30 +<br>(0x60 *(n-1)) | R/W | IFn Arbitration 1 Registers                         | 0x0000_0000 |
| <b>CAN_IFn_ARB2<br/>n=1,2</b>   | CAN_BA+0x34 +<br>(0x60 *(n-1)) | R/W | IFn Arbitration 2 Registers                         | 0x0000_0000 |
| <b>CAN_IFn_MCON<br/>n=1,2</b>   | CAN_BA+0x38 +<br>(0x60 *(n-1)) | R/W | IFn Message Control Registers                       | 0x0000_0000 |
| <b>CAN_IFn_DAT_A1<br/>n=1,2</b> | CAN_BA+0x3C +<br>(0x60 *(n-1)) | R/W | IFn Data A1 Registers (Register Map Note 3)         | 0x0000_0000 |
| <b>CAN_IFn_DAT_A2<br/>n=1,2</b> | CAN_BA+0x40 +<br>(0x60 *(n-1)) | R/W | IFn Data A2 Registers (Register Map Note 3)         | 0x0000_0000 |
| <b>CAN_IFn_DAT_B1<br/>n=1,2</b> | CAN_BA+0x44 +<br>(0x60 *(n-1)) | R/W | IFn Data B1 Registers (Register Map Note 3)         | 0x0000_0000 |
| <b>CAN_IFn_DAT_B2<br/>n=1,2</b> | CAN_BA+0x48 +<br>(0x60 *(n-1)) | R/W | IFn Data B2 Registers (Register Map Note 3)         | 0x0000_0000 |
| <b>CAN_TXREQ1</b>               | CAN_BA+0x100                   | R   | Transmission Request Register 1                     | 0x0000_0000 |
| <b>CAN_TXREQ2</b>               | CAN_BA+0x104                   | R   | Transmission Request Register 2                     | 0x0000_0000 |
| <b>CAN_NDAT1</b>                | CAN_BA+0x120                   | R   | New Data Register 1                                 | 0x0000_0000 |

|               |              |     |                                 |             |
|---------------|--------------|-----|---------------------------------|-------------|
| CAN_NDAT2     | CAN_BA+0x124 | R   | New Data Register 2             | 0x0000_0000 |
| CAN_IPND1     | CAN_BA+0x140 | R   | Interrupt Pending Register 1    | 0x0000_0000 |
| CAN_IPND2     | CAN_BA+0x144 | R   | Interrupt Pending Register 2    | 0x0000_0000 |
| CAN_MVLD1     | CAN_BA+0x160 | R   | Message Valid Register 1        | 0x0000_0000 |
| CAN_MVLD2     | CAN_BA+0x164 | R   | Message Valid Register 2        | 0x0000_0000 |
| CAN_WU_EN     | CAN_BA+0x168 | R/W | Wake-up Enable Control Register | 0x0000_0000 |
| CAN_WU_STATUS | CAN_BA+0x16C | R/W | Wake-up Status Register         | 0x0000_0000 |

**Note:**

4. 0x00 & 0br0000000, where r signifies the actual value of the CAN\_RX
1. IFn: The two sets of Message Interface Registers – IF1 and IF2, have identical function
2. An/Bn: The two sets of data registers – A1, A2 and B1, B2.
3. CAN\_BA, where x = 0 or 1.

## CAN Register Map for Each Bit Function

| Addr Offset | Register Name  | 15     | 14   | 13  | 12    | 11 | 10 | 9     | 8 | 7      | 6     | 5     | 4       | 3        | 2       | 1              | 0 |
|-------------|----------------|--------|------|-----|-------|----|----|-------|---|--------|-------|-------|---------|----------|---------|----------------|---|
| 00h         | CAN_CON        |        |      |     |       |    |    |       |   | Test   | CCE   | DAR   | Res     | EIE      | IE      | Init           |   |
| 04h         | CAN_STATUS     |        |      |     |       |    |    |       |   | Boff   | EWarn | EPass | RxOk    | TxOk     | SIE     | LEC            |   |
| 08h         | CAN_ERR        | RP     |      |     |       |    |    |       |   |        |       |       |         |          |         | TEC7-0         |   |
| 0Ch         | CAN_BTIME      | Res    |      |     | TSeg2 |    |    | TSeg1 |   | SJW    |       |       |         |          |         | BRP            |   |
| 10h         | CAN_IIDR       |        |      |     |       |    |    |       |   |        |       |       |         |          |         | IntId7-0       |   |
| 14h         | CAN_TEST       |        |      |     |       |    |    |       |   | RX     | Tx1   | Tx0   | LBack   | Silent   | Basic   | Reserved       |   |
| 18h         | CAN_BRPE       |        |      |     |       |    |    |       |   |        |       |       |         |          |         | BRPE           |   |
| 20h         | CAN_IF1_CRE_Q  | Busy   |      |     |       |    |    |       |   |        |       |       |         |          |         | Message Number |   |
| 24h         | CAN_IF1_CMASK  |        |      |     |       |    |    |       |   | \WR/RD | Mask  | Arb   | Control | ClIntPnd | TxRqst/ | Data A         |   |
| 28h         | CAN_IF1_MAS_K1 |        |      |     |       |    |    |       |   |        |       |       |         |          |         | Data B         |   |
| 2Ch         | CAN_IF1_MAS_K2 | MXtd   | MDir | Res |       |    |    |       |   |        |       |       |         |          |         | Msk28-16       |   |
| 30h         | CAN_IF1_ARB_1  |        |      |     |       |    |    |       |   |        |       |       |         |          |         | ID15-0         |   |
| 34h         | CAN_IF1_ARB_2  | MsgVal | Xtd  | Dir |       |    |    |       |   |        |       |       |         |          |         | ID28-16        |   |

| Addr Offset | Register Name  | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2  | 1<br>1 | 1<br>0 | 9     | 8      | 7   | 6        | 5        | 4      | 3              | 2 | 1 | 0 |
|-------------|----------------|--------|--------|--------|---------|--------|--------|-------|--------|-----|----------|----------|--------|----------------|---|---|---|
| 38h         | CAN_IF1_MCO_N  | NewDat | MsgLst | IntPnd | UMask   | TxE    | RxE    | RmtEn | TxRqst | EoB | Reserved | Reserved | DLC3-0 |                |   |   |   |
| 3Ch         | CAN_IF1_DAT_A1 |        |        |        | Data(1) |        |        |       |        |     | Data(0)  |          |        |                |   |   |   |
| 40h         | CAN_IF1_DAT_A2 |        |        |        | Data(3) |        |        |       |        |     | Data(2)  |          |        |                |   |   |   |
| 44h         | CAN_IF1_DAT_B1 |        |        |        | Data(5) |        |        |       |        |     | Data(4)  |          |        |                |   |   |   |
| 48h         | CAN_IF1_DAT_B2 |        |        |        | Data(7) |        |        |       |        |     | Data(6)  |          |        |                |   |   |   |
| 80h         | CAN_IF2_CREQ   | Busy   |        |        |         |        |        |       |        |     |          |          |        | Message Number |   |   |   |
| 84h         | CAN_IF2_CMASK  |        |        |        |         |        |        |       |        |     |          |          |        |                |   |   |   |
| 88h         | CAN_IF2_MASK_1 |        |        |        |         |        |        |       |        |     | Msk15-0  |          |        |                |   |   |   |
| 8Ch         | CAN_IF2_MASK_2 | MXtd   | MDir   | Res.   |         |        |        |       |        |     | Msk28-16 |          |        |                |   |   |   |
| 90h         | CAN_IF2_ARB1   |        |        |        |         |        |        |       |        |     | ID15-0   |          |        |                |   |   |   |
| 94h         | CAN_IF2_ARB2   | MsgVal | Xtd    | Dir    |         |        |        |       |        |     |          |          |        | ID28-16        |   |   |   |
| 98h         | CAN_IF2_MCO_N  | NewDat | MsgLst | IntPnd | UMask   | TxE    | RxE    | RmtEn | TxRqst | EoB | Reserved | Reserved | DLC3-0 |                |   |   |   |
| 9Ch         | CAN_IF2_DAT_A1 |        |        |        | Data(1) |        |        |       |        |     | Data(0)  |          |        |                |   |   |   |

| Addr Offset | Register Name  | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5       | 4 | 3 | 2 | 1 | 0 |
|-------------|----------------|-------------|----|----|----|----|----|---|---|---|---|---------|---|---|---|---|---|
| A0h         | CAN_IF2_DAT_A2 | Data(3)     |    |    |    |    |    |   |   |   |   | Data(2) |   |   |   |   |   |
| A4h         | CAN_IF2_DAT_B1 | Data(5)     |    |    |    |    |    |   |   |   |   | Data(4) |   |   |   |   |   |
| A8h         | CAN_IF2_DAT_B2 | Data(7)     |    |    |    |    |    |   |   |   |   | Data(6) |   |   |   |   |   |
| 100h        | CAN_TXREQ1     | TxRqst16-1  |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 104h        | CAN_TXREQ2     | TxRqst32-17 |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 120h        | CAN_NDAT1      | NewDat16-1  |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 124h        | CAN_NDAT2      | NewDat32-17 |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 140h        | CAN_IPND1      | IntPnd16-1  |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 144h        | CAN_IPND2      | IntPnd32-17 |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 160h        | CAN_MVLD1      | MsgVal16-1  |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 164h        | CAN_MVLD2      | MsgVal32-17 |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 168h        | CAN_WU_EN      | Reserved    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 16Ch        | CAN_WU_STAT_US | Reserved    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| 170h        | CAN_RAM_CEN    | Reserved    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |
| Others      | Reserved       | Reserved    |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   |

Table 6.27-4 CAN Register Map for Each Bit Function

**Note:** Reserved bits are read as '0' except for IFn Mask 2 Register where they are read as '1'.

Res. = Reserved

### 6.27.9 Register Description

The C\_CAN allocates an address space of 256 bytes. The registers are organized as 16-bit registers.

The two sets of interface registers (IF1 and IF2) control the software access to the Message RAM. They buffer the data to be transferred to and from the RAM, avoiding conflicts between software accesses and message reception/transmission.

CAN Control Register (CAN\_CON)

| Register | Offset      | R/W | Description      |  |  |  |  | Reset Value |
|----------|-------------|-----|------------------|--|--|--|--|-------------|
| CAN_CON  | CAN_BA+0x00 | R/W | Control Register |  |  |  |  | 0x0000_0001 |

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

| Bits   | Description                                                                                                                                                                                                                                               |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                              |
| [7]    | <b>Test</b><br><b>Test Mode Enable Bit</b><br>0 = Normal Operation.<br>1 = Test Mode.                                                                                                                                                                     |
| [6]    | <b>CCE</b><br><b>Configuration Change Enable Bit</b><br>0 = No write access to the Bit Timing Register.<br>1 = Write access to the Bit Timing Register (CAN_BTIME) allowed. (while Init bit (CAN_CON[0]) = 1).                                            |
| [5]    | <b>DAR</b><br><b>Automatic Re-transmission Disable Bit</b><br>0 = Automatic Retransmission of disturbed messages Enabled.<br>1 = Automatic Retransmission Disabled.                                                                                       |
| [4]    | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                              |
| [3]    | <b>EIE</b><br><b>Error Interrupt Enable Bit</b><br>0 = Disabled - No Error Status Interrupt will be generated.<br>1 = Enabled - A change in the bits BOff (CAN_STATUS[7]) or EWarn (CAN_STATUS[6]) in the Status Register will generate an interrupt.     |
| [2]    | <b>SIE</b><br><b>Status Change Interrupt Enable Bit</b><br>0 = Disabled - No Status Change Interrupt will be generated.<br>1 = Enabled - An interrupt will be generated when a message transfer is successfully completed or a CAN bus error is detected. |
| [1]    | <b>IE</b><br><b>Module Interrupt Enable Bit</b><br>0 = Function interrupt Disabled.<br>1 = Function interrupt Enabled.                                                                                                                                    |
| [0]    | <b>Init</b><br><b>Init Initialization</b><br>0 = Normal Operation.<br>1 = Initialization is started.                                                                                                                                                      |

**Note:** The bus-off recovery sequence (see CAN Specification Rev. 2.0) cannot be shortened by

setting or resetting the Init bit (CAN\_CON[0]). If the device goes in the bus-off state, it will set Init of its own accord, stopping all bus activities. Once Init has been cleared by the CPU, the device will then wait for 129 occurrences of Bus Idle (129 \* 11 consecutive recessive bits) before resuming normal operations. At the end of the bus-off recovery sequence, the Error Management Counters will be reset.

During the waiting time after resetting Init, each time a sequence of 11 recessive bits has been monitored, a Bit0Error code is written to the Status Register, enabling the CPU to readily check up whether the CAN bus is stuck at dominant or continuously disturbed and to monitor the proceeding of the bus-off recovery sequence.

**CAN Status Register (CAN\_STATUS)**

| Register   | Offset      | R/W | Description     |  |  |  | Reset Value |
|------------|-------------|-----|-----------------|--|--|--|-------------|
| CAN_STATUS | CAN_BA+0x04 | R/W | 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  |
| BOff     | EWarn | EPass | RxOK | TxOK | LEC |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                              |
| [7]    | BOff        | <b>Bus-off Status (Read Only)</b><br>0 = The CAN module is not in bus-off state.<br>1 = The CAN module is in bus-off state.                                                                                                                                                                                                                                                                                            |
| [6]    | EWarn       | <b>Error Warning Status (Read Only)</b><br>0 = Both error counters are below the error warning limit of 96.<br>1 = At least one of the error counters in the EML has reached the error warning limit of 96.                                                                                                                                                                                                            |
| [5]    | EPass       | <b>Error Passive (Read Only)</b><br>0 = The CAN Core is error active.<br>1 = The CAN Core is in the error passive state as defined in the CAN Specification.                                                                                                                                                                                                                                                           |
| [4]    | RxOK        | <b>Received a Message Successfully</b><br>0 = No message has been successfully received since this bit was last reset by the CPU.<br>This bit is never reset by the CAN Core.<br>1 = A message has been successfully received since this bit was last reset by the CPU<br>(independent of the result of acceptance filtering).                                                                                         |
| [3]    | TxOK        | <b>Transmitted a Message Successfully</b><br>0 = Since this bit was reset by the CPU, no message has been successfully transmitted. This bit is never reset by the CAN Core.<br>1 = Since this bit was last reset by the CPU, a message has been successfully (error free and acknowledged by at least one other node) transmitted.                                                                                    |
| [2:0]  | LEC         | <b>Last Error Code (Type of the Last Error to Occur on the CAN Bus)</b><br>The LEC field holds a code, which indicates the type of the last error to occur on the CAN bus. This field will be cleared to '0' when a message has been transferred (reception or transmission) without error. The unused code '7' may be written by the CPU to check for updates. Table 6.27-5 Last Error Code describes the error code. |

| Error Code | Meanings |
|------------|----------|
|------------|----------|

|   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | No Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1 | Stuff Error: More than 5 equal bits in a sequence have occurred in a part of a received message where this is not allowed.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2 | Form Error: A fixed format part of a received frame has the wrong format.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3 | AckError: The message this CAN Core transmitted was not acknowledged by another node.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4 | Bit1Error: During the transmission of a message (with the exception of the arbitration field), the device wanted to send a recessive level (bit of logical value '1'), but the monitored bus value was dominant.                                                                                                                                                                                                                                                                                                           |
| 5 | Bit0Error: During the transmission of a message (or acknowledge bit, or active error flag, or overload flag), though the device wanted to send a dominant level (data or identifier bit logical value '0'), but the monitored Bus value was recessive. During bus-off recovery, this status is set each time a sequence of 11 recessive bits has been monitored. This enables the CPU to monitor the proceedings of the bus-off recovery sequence (indicating the bus is not stuck at dominant or continuously disturbed). |
| 6 | CRCError: The CRC check sum was incorrect in the message received, the CRC received for an incoming message does not match with the calculated CRC for the received data.                                                                                                                                                                                                                                                                                                                                                  |
| 7 | Unused: When the LEC shows the value '7', no CAN bus event was detected since the CPU wrote this value to the LEC.                                                                                                                                                                                                                                                                                                                                                                                                         |

Table 6.27-5 Last Error Code

### Status Interrupts

A Status Interrupt is generated by bits BOff (CAN\_STATUS[7]) and EWarn (CAN\_STATUS[6]) (Error Interrupt) or by RxOk (CAN\_STATUS[4]), TxOk (CAN\_STATUS[3]) and LEC (CAN\_STATUS[2:0]) (Status Change Interrupt) assumed that the corresponding enable bits in the CAN Control Register are set. A change of bit EPass (CAN\_STATUS[5]) or a write to RxOk, TxOk or LEC will never generate a Status Interrupt.

Reading the Status Register will clear the Status Interrupt value (8000h) in the Interrupt Register, if it is pending.

CAN Error Counter Register (CAN\_ERR)

| Register | Offset      | R/W | Description            |  |  |  |  | Reset Value |
|----------|-------------|-----|------------------------|--|--|--|--|-------------|
| CAN_ERR  | CAN_BA+0x08 | R   | Error 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  |
| RP       | REC |    |    |    |    |    |    |
| 7        | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| TEC      |     |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                                           |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                 |
| [15]    | RP          | <b>Receive Error Passive</b><br>0 = The Receive Error Counter is below the error passive level.<br>1 = The Receive Error Counter has reached the error passive level as defined in the CAN Specification. |
| [14:8]  | REC         | <b>Receive Error Counter</b><br>Actual state of the Receive Error Counter. Values between 0 and 127.                                                                                                      |
| [7:0]   | TEC         | <b>Transmit Error Counter</b><br>Actual state of the Transmit Error Counter. Values between 0 and 255.                                                                                                    |

**Bit Timing Register (CAN\_BTIME)**

| Register  | Offset      | R/W | Description         |  |  |  |  | Reset Value |
|-----------|-------------|-----|---------------------|--|--|--|--|-------------|
| CAN_BTIME | CAN_BA+0x0C | R/W | Bit Timing Register |  |  |  |  | 0x0000_2301 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:15] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |
| [14:12] | TSeg2       | <b>Time Segment After Sample Point</b><br>0x0-0x7: Valid values for TSeg2 are [0...7]. The actual interpretation by the hardware of this value is such that one more than the value programmed here is used.                                                                                                                                                              |
| [11:8]  | TSeg1       | <b>Time Segment Before the Sample Point Minus Sync_Seg</b><br>0x01-0x0F: valid values for TSeg1 are [1...15]. The actual interpretation by the hardware of this value is such that one more than the value programmed is used.                                                                                                                                            |
| [7:6]   | SJW         | <b>(Re)Synchronization Jump Width</b><br>0x0-0x3: Valid programmed values are [0...3]. The actual interpretation by the hardware of this value is such that one more than the value programmed here is used.                                                                                                                                                              |
| [5:0]   | BRP         | <b>Baud Rate Prescaler</b><br>0x01-0x3F: The value by which the oscillator frequency is divided for generating the bit time quanta. The bit time is built up from a multiple of this quanta. Valid values for the Baud Rate Prescaler are [0...63]. The actual interpretation by the hardware of this value is such that one more than the value programmed here is used. |

**Note:** With a module clock APB\_CLK of 8 MHz, the reset value of 0x2301 configures the C\_CAN for a bit rate of 500 Kbit/s. The registers are only writable if bits CCE (CAN\_CON[6]) and Init (CAN\_CON[0]) are set.

Interrupt Identify Register (CAN\_IIDR)

| Register | Offset      | R/W | Description                   |  |  |  | Reset Value |
|----------|-------------|-----|-------------------------------|--|--|--|-------------|
| CAN_IIDR | CAN_BA+0x10 | R   | Interrupt Identifier 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  |
| IntId    |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| IntId    |    |    |    |    |    |    |    |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0] | <p><b>IntId</b></p> <p><b>Interrupt Identifier (Indicates the Source of the Interrupt)</b></p> <p>If several interrupts are pending, the CAN Interrupt Register will point to the pending interrupt with the highest priority, disregarding their chronological order. An interrupt remains pending until the application software has cleared it. If IntId is different from 0x0000 and IE (CAN_CON[1]) is set, the IRQ interrupt signal to the EIC is active. The interrupt remains active until IntId is back to value 0x0000 (the cause of the interrupt is reset) or until IE is reset.</p> <p>The Status Interrupt has the highest priority. Among the message interrupts, the Message Object's interrupt priority decreases with increasing message number.</p> <p>A message interrupt is cleared by clearing the Message Object's IntPnd bit (CAN_IFn_MCON[13]). The Status Interrupt is cleared by reading the Status Register.</p> |

| IntId Value   | Meanings                                             |
|---------------|------------------------------------------------------|
| 0x0000        | No Interrupt is Pending                              |
| 0x0001-0x0020 | Number of Message Object which caused the interrupt. |
| 0x0021-0x7FFF | Unused                                               |
| 0x8000        | Status Interrupt                                     |
| 0x8001-0xFFFF | Unused                                               |

Table 6.27-6 Source of Interrupts

**Test Register (CAN\_TEST)**

| Register | Offset      | R/W | Description                         |  |  |  | Reset Value |
|----------|-------------|-----|-------------------------------------|--|--|--|-------------|
| CAN_TEST | CAN_BA+0x14 | R/W | Test Register (Register Map Note 1) |  |  |  | 0x0000_0080 |

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

| Bits   | Description                                                                                                                                                                                                                                                       |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | <b>Reserved</b> Reserved.                                                                                                                                                                                                                                         |
| [7]    | <b>Rx</b> Monitors the Actual Value of CAN_RX Pin (Read Only) *(1)<br>0 = The CAN bus is dominant (CAN_RX = '0').<br>1 = The CAN bus is recessive (CAN_RX = '1').                                                                                                 |
| [6:5]  | <b>Tx</b> Tx[1:0]: Control of CAN_TX Pin<br>00 = Reset value, CAN_TX pin is controlled by the CAN Core.<br>01 = Sample Point can be monitored at CAN_TX pin.<br>10 = CAN_TX pin drives a dominant ('0') value.<br>11 = CAN_TX pin drives a recessive ('1') value. |
| [4]    | <b>LBack</b> Loop Back Mode Enable Bit<br>0 = Loop Back Mode Disabled.<br>1 = Loop Back Mode Enabled.                                                                                                                                                             |
| [3]    | <b>Silent</b> Silent Mode<br>0 = Normal operation.<br>1 = The module is in Silent Mode.                                                                                                                                                                           |
| [2]    | <b>Basic</b> Basic Mode<br>0 = Basic Mode Disabled.<br>1= IF1 Registers used as Tx Buffer, IF2 Registers used as Rx Buffer.                                                                                                                                       |
| [1:0]  | <b>Reserved</b> Reserved.                                                                                                                                                                                                                                         |

Reset value: 0000 0000 R000 0000 b (R:current value of RX pin)

**Note:** Write access to the Test Register is enabled by setting the Test bit (CAN\_CON[7]). The different test functions may be combined, but Tx[1-0] "00" (CAN\_TEST[6:5]) disturbs message transfer.

**Baud Rate Prescaler Extension REGISTER (CAN\_BRPE)**

| Register | Offset      | R/W | Description                            |  |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------------------|--|--|--|--|-------------|
| CAN_BRPE | CAN_BA+0x18 | R/W | Baud Rate Prescaler Extension 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 |    |    |    |    | BRPE |    |    |  |

| Bits   | Description |                                                                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |
| [3:0]  | BRPE        | <b>BRPE: Baud Rate Prescaler Extension</b><br>0x00-0x0F: By programming BRPE, the Baud Rate Prescaler can be extended to values up to 1023. The actual interpretation by the hardware is that one more than the value programmed by BRPE (MSBs) and BTIME (LSBs) is used. |

### Message Interface Register Sets

There are two sets of Interface Registers, which are used to control the CPU access to the Message RAM. The Interface Registers avoid conflict between the CPU accesses to the Message RAM and CAN message reception and transmission by buffering the data to be transferred. A complete Message Object or parts of the Message Object may be transferred between the Message RAM and the IFn Message Buffer registers in one single transfer.

The function of the two interface register sets is identical except for the Basic test mode. They can be used the way one set of registers is used for data transfer to the Message RAM while the other set of registers is used for the data transfer from the Message RAM, allowing both processes to be interrupted by each other. Table 6.27-7 provides an overview of the two Interface Register sets.

Each set of Interface Registers consists of Message Buffer Registers controlled by their own Command Registers. The Command Mask Register specifies the direction of the data transfer and which parts of a Message Object will be transferred. The Command Request Register is used to select a Message Object in the Message RAM as target or source for the transfer and to start the action specified in the Command Mask Register.

| Address     | IF1 Register Set    | Address     | IF2 Register Set    |
|-------------|---------------------|-------------|---------------------|
| CAN_BA+0x20 | IF1 Command Request | CAN_BA+0x80 | IF2 Command Request |
| CAN_BA+0x24 | IF1 Command Mask    | CAN_BA+0x84 | IF2 Command Mask    |
| CAN_BA+0x28 | IF1 Mask 1          | CAN_BA+0x88 | IF2 Mask 1          |
| CAN_BA+0x2C | IF1 Mask 2          | CAN_BA+0x8C | IF2 Mask 2          |
| CAN_BA+0x30 | IF1 Arbitration 1   | CAN_BA+0x90 | IF2 Arbitration 1   |
| CAN_BA+0x34 | IF1 Arbitration 2   | CAN_BA+0x94 | IF2 Arbitration 2   |
| CAN_BA+0x38 | IF1 Message Control | CAN_BA+0x98 | IF2 Message Control |
| CAN_BA+0x3C | IF1 Data A 1        | CAN_BA+0x9C | IF2 Data A 1        |
| CAN_BA+0x40 | IF1 Data A 2        | CAN_BA+0xA0 | IF2 Data A 2        |
| CAN_BA+0x44 | IF1 Data B 1        | CAN_BA+0xA4 | IF2 Data B 1        |
| CAN_BA+0x48 | IF1 Data B 2        | CAN_BA+0xA8 | IF2 Data B 2        |

Table 6.27-7 IF1 and IF2 Message Interface Register

IFn Command Request Register (CAN\_IFn\_CREQ)

| Register     | Offset                      | R/W | Description                                         |  |  |  | Reset Value |
|--------------|-----------------------------|-----|-----------------------------------------------------|--|--|--|-------------|
| CAN_IFn_CREQ | CAN_BA+0x20 + (0x60 *(n-1)) | R/W | IFn (Register Map Note 2) Command Request Registers |  |  |  | 0x0000_0001 |

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

| Bits    | Description    |                                                                                                                                                                                                                                                              |
|---------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved       | Reserved.                                                                                                                                                                                                                                                    |
| [15]    | Busy           | <b>Busy Flag</b><br>0 = Read/write action has finished.<br>1 = Writing to the IFn Command Request Register is in progress. This bit can only be read by the software.                                                                                        |
| [14:6]  | Reserved       | Reserved.                                                                                                                                                                                                                                                    |
| [5:0]   | Message Number | <b>Message Number</b><br>0x01-0x20: Valid Message Number, the Message Object in the Message RAM is selected for data transfer.<br>0x00: Not a valid Message Number, interpreted as 0x20.<br>0x21-0x3F: Not a valid Message Number, interpreted as 0x01-0x1F. |

A message transfer is started as soon as the application software has written the message number to the Command Request Register. With this write operation, the Busy bit (CAN\_IFn\_CREQ[15]) is automatically set to notify the CPU that a transfer is in progress. After a waiting time of 3 to 6 APB\_CLK periods, the transfer between the Interface Register and the Message RAM is completed. The Busy bit is cleared.

**Note:** When a Message Number that is not valid is written into the Command Request Register, the Message Number will be transformed into a valid value and that Message Object will be transferred.

**IFn Command Mask Register (CAN\_IFn\_CMASK)**

The control bits of the IFn Command Mask Register specify the transfer direction and select which of the IFn Message Buffer Registers are source or target of the data transfer.

| Register      | Offset                      | R/W | Description                |  |  |  | Reset Value |
|---------------|-----------------------------|-----|----------------------------|--|--|--|-------------|
| CAN_IFn_CMASK | CAN_BA+0x24 + (0x60 *(n-1)) | R/W | IFn Command Mask Registers |  |  |  | 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     |
| WR/RD    | Mask | Arb | Control | ClrIntPnd | TxRqst/NewDat | DAT_A | DAT_B |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                               |
| [7]    | WR/RD       | <b>Write / Read Mode</b><br>0 = Read: Transfer data from the Message Object addressed by the Command Request Register into the selected Message Buffer Registers.<br>1 = Write: Transfer data from the selected Message Buffer Registers to the Message Object addressed by the Command Request Register.                                               |
| [6]    | Mask        | <b>Access Mask Bits</b><br>Write Operation:<br>0 = Mask bits unchanged.<br>1 = Transfer Identifier Mask + MDir + MXtd to Message Object.<br>Read Operation:<br>0 = Mask bits unchanged.<br>1 = Transfer Identifier Mask + MDir + MXtd to IFn Message Buffer Register.                                                                                   |
| [5]    | Arb         | <b>Access Arbitration Bits</b><br>Write Operation:<br>0 = Arbitration bits unchanged.<br>1 = Transfer Identifier + Dir (CAN_IFn_ARB2[13]) + Xtd (CAN_IFn_ARB2[14]) + MsgVal (CAN_IFn_ARB2[15]) to Message Object.<br>Read Operation:<br>0 = Arbitration bits unchanged.<br>1 = Transfer Identifier + Dir + Xtd + MsgVal to IFn Message Buffer Register. |
| [4]    | Control     | <b>Control Access Control Bits</b><br>Write Operation:<br>0 = Control Bits unchanged.<br>1 = Transfer Control Bits to Message Object.                                                                                                                                                                                                                   |

|     |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                      | Read Operation:<br>0 = Control Bits unchanged.<br>1 = Transfer Control Bits to IFn Message Buffer Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3] | <b>ClrIntPnd</b>     | <b>Clear Interrupt Pending Bit</b><br>Write Operation:<br>When writing to a Message Object, this bit is ignored.<br>Read Operation:<br>0 = IntPnd bit (CAN_IFn_MCON[13]) remains unchanged.<br>1 = Clear IntPnd bit in the Message Object.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [2] | <b>TxRqst/NewDat</b> | <b>Access Transmission Request Bit When Write Operation</b><br>0 = TxRqst bit unchanged.<br>1 = Set TxRqst bit.<br><b>Note:</b> If a transmission is requested by programming bit TxRqst/NewDat in the IFn Command Mask Register, bit TxRqst in the IFn Message Control Register will be ignored.<br><b>Access New Data Bit when Read Operation.</b><br>0 = NewDat bit remains unchanged.<br>1 = Clear NewDat bit in the Message Object.<br><b>Note:</b> A read access to a Message Object can be combined with the reset of the control bits IntPnd and NewDat. The values of these bits transferred to the IFn Message Control Register always reflect the status before resetting these bits. |
| [1] | <b>DAT_A</b>         | <b>Access Data Bytes [3:0]</b><br>Write Operation:<br>0 = Data Bytes [3:0] unchanged.<br>1 = Transfer Data Bytes [3:0] to Message Object.<br>Read Operation:<br>0 = Data Bytes [3:0] unchanged.<br>1 = Transfer Data Bytes [3:0] to IFn Message Buffer Register.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [0] | <b>DAT_B</b>         | <b>Access Data Bytes [7:4]</b><br>Write Operation:<br>0 = Data Bytes [7:4] unchanged.<br>1 = Transfer Data Bytes [7:4] to Message Object.<br>Read Operation:<br>0 = Data Bytes [7:4] unchanged.<br>1 = Transfer Data Bytes [7:4] to IFn Message Buffer Register.                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**IFn Mask 1 Register (CAN\_IFn\_MASK1)**

| Register      | Offset                         | R/W | Description          | Reset Value |
|---------------|--------------------------------|-----|----------------------|-------------|
| CAN_IFn_MASK1 | CAN_BA+0x28 +<br>(0x60 *(n-1)) | R/W | IFn Mask 1 Registers | 0x0000_FFFF |



| Bits    | Description |                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                        |
| [15:0]  | Msk         | <b>Identifier Mask 15-0</b><br>0 = The corresponding bit in the identifier of the message object cannot inhibit the match in the acceptance filtering.<br>1 = The corresponding identifier bit is used for acceptance filtering. |

**IFn Mask 2 Register (CAN\_IFn\_MASK2)**

| Register      | Offset                         | R/W | Description          | Reset Value |
|---------------|--------------------------------|-----|----------------------|-------------|
| CAN_IFn_MASK2 | CAN_BA+0x2C +<br>(0x60 *(n-1)) | R/W | IFn Mask 2 Registers | 0x0000_FFFF |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [15]    | MXtd        | <b>Mask Extended Identifier</b><br>0 = The extended identifier bit (IDE) has no effect on the acceptance filtering.<br>1 = The extended identifier bit (IDE) is used for acceptance filtering.<br><b>Note:</b> When 11-bit ("standard") Identifiers are used for a Message Object, the identifiers of received Data Frames are written into bits ID28 to ID18 (CAN_IFn_ARB2[12:2]). For acceptance filtering, only these bits together with mask bits Msk28 to Msk18 (CAN_IFn_MASK2[12:2]) are considered. |
| [14]    | MDir        | <b>Mask Message Direction</b><br>0 = The message direction bit (Dir (CAN_IFn_ARB2[13])) has no effect on the acceptance filtering.<br>1 = The message direction bit (Dir) is used for acceptance filtering.                                                                                                                                                                                                                                                                                                |
| [13]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [12:0]  | Msk         | <b>Identifier Mask 28-16</b><br>0 = The corresponding bit in the identifier of the message object cannot inhibit the match in the acceptance filtering.<br>1 = The corresponding identifier bit is used for acceptance filtering.                                                                                                                                                                                                                                                                          |

**IFn Arbitration 1 Register (CAN\_IFn\_ARB1)**

| Register     | Offset                      | R/W | Description                 |  |  |  | Reset Value |
|--------------|-----------------------------|-----|-----------------------------|--|--|--|-------------|
| CAN_IFn_ARB1 | CAN_BA+0x30 + (0x60 *(n-1)) | R/W | IFn Arbitration 1 Registers |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                |
| [15:0]  | ID          | <b>Message Identifier 15-0</b><br>ID28 - ID0, 29-bit Identifier ("Extended Frame").<br>ID28 - ID18, 11-bit Identifier ("Standard Frame") |

**IFn Arbitration 2 Register (CAN\_IFn\_ARB2)**

| Register     | Offset                      | R/W | Description                 |  |  |  | Reset Value |
|--------------|-----------------------------|-----|-----------------------------|--|--|--|-------------|
| CAN_IFn_ARB2 | CAN_BA+0x34 + (0x60 *(n-1)) | R/W | IFn Arbitration 2 Registers |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [15]    | MsgVal      | <p><b>Message Valid</b><br/>           0 = The Message Object is ignored by the Message Handler.<br/>           1 = The Message Object is configured and should be considered by the Message Handler.</p> <p><b>Note:</b> The application software must reset the MsgVal bit of all unused Messages Objects during the initialization before it resets bit Init (CAN_CON[0]). This bit must also be reset before the identifier Id28-0 (CAN_IFn_ARB1/2), the control bits Xtd (CAN_IFn_ARB2[14]), Dir (CAN_IFn_ARB2[13]), or the Data Length Code DLC3-0 (CAN_IFn_MCON[3:0]) are modified, or if the Messages Object is no longer required.</p> |
| [14]    | Xtd         | <p><b>Extended Identifier</b><br/>           0 = The 11-bit (“standard”) Identifier will be used for this Message Object.<br/>           1 = The 29-bit (“extended”) Identifier will be used for this Message Object.</p>                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [13]    | Dir         | <p><b>Message Direction</b><br/>           0 = Direction is receive.<br/>           On TxRqst, a Remote Frame with the identifier of this Message Object is transmitted. On reception of a Data Frame with matching identifier, that message is stored in this Message Object.<br/>           1 = Direction is transmit.<br/>           On TxRqst, the respective Message Object is transmitted as a Data Frame. On reception of a Remote Frame with matching identifier, the TxRqst bit (CAN_IFn_CMASK[2]) of this Message Object is set (if RmtEn (CAN_IFn_MCON[9]) = one).</p>                                                               |
| [12:0]  | ID          | <p><b>Message Identifier 28-16</b><br/>           ID28 - ID0, 29-bit Identifier (“Extended Frame”).<br/>           ID28 - ID18, 11-bit Identifier (“Standard Frame”)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**IFn Message Control Register (CAN\_IFn\_MCON)**

| Register     | Offset                      | R/W | Description                   |  |  |  | Reset Value |
|--------------|-----------------------------|-----|-------------------------------|--|--|--|-------------|
| CAN_IFn_MCON | CAN_BA+0x38 + (0x60 *(n-1)) | R/W | IFn Message Control Registers |  |  |  | 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      |
| NewDat   | MsgLst   | IntPnd | UMask | TxE | RxE | RmtEn | TxRqst |
| 7        | 6        | 5      | 4     | 3   | 2   | 1     | 0      |
| EoB      | Reserved |        |       | DLC |     |       |        |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                 |
| [15]    | NewDat      | <p><b>New Data</b><br/>           0 = No new data has been written into the data portion of this Message Object by the Message Handler since last time this flag was cleared by the application software.<br/>           1 = The Message Handler or the application software has written new data into the data portion of this Message Object.</p>       |
| [14]    | MsgLst      | <p><b>Message Lost</b><br/>           0 = No message lost since last time this bit was reset by the CPU.<br/>           1 = The Message Handler stored a new message into this object when NewDat was still set, the CPU has lost a message.<br/> <b>Note:</b> Only valid for Message Objects with direction = receive.</p>                               |
| [13]    | IntPnd      | <p><b>Interrupt Pending</b><br/>           0 = This message object is not the source of an interrupt.<br/>           1 = This message object is the source of an interrupt. The Interrupt Identifier in the Interrupt Register will point to this message object if there is no other interrupt source with higher priority.</p>                          |
| [12]    | UMask       | <p><b>Use Acceptance Mask</b><br/>           0 = Mask ignored.<br/>           1 = Use Mask (Msk28-0, MXtd, and MDir) for acceptance filtering.<br/> <b>Note:</b> If the UMask bit is set to one, the Message Object's mask bits have to be programmed during initialization of the Message Object before MsgVal bit (CAN_IFn_ARB2[15]) is set to one.</p> |
| [11]    | TxE         | <p><b>Transmit Interrupt Enable Bit</b><br/>           0 = IntPnd (CAN_IFn_MCON[13]) will be left unchanged after the successful transmission of a frame.<br/>           1 = IntPnd will be set after a successful transmission of a frame.</p>                                                                                                           |
| [10]    | RxE         | <p><b>Receive Interrupt Enable Bit</b><br/>           0 = IntPnd (CAN_IFn_MCON[13]) will be left unchanged after a successful reception of a frame.</p>                                                                                                                                                                                                   |

|       |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 | 1 = IntPnd will be set after a successful reception of a frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [9]   | <b>RmtEn</b>    | <p><b>Remote Enable Bit</b></p> <p>0 = At the reception of a Remote Frame, TxRqst (CAN_IFn_MCON[8]) is left unchanged.<br/>     1 = At the reception of a Remote Frame, TxRqst is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [8]   | <b>TxRqst</b>   | <p><b>Transmit Request</b></p> <p>0 = This Message Object is not waiting for transmission.<br/>     1 = The transmission of this Message Object is requested and is not yet done.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [7]   | <b>EoB</b>      | <p><b>End of Buffer</b></p> <p>0 = Message Object belongs to a FIFO Buffer and is not the last Message Object of that FIFO Buffer.<br/>     1 = Single Message Object or last Message Object of a FIFO Buffer.</p> <p><b>Note:</b> This bit is used to concatenate two or more Message Objects (up to 32) to build a FIFO Buffer. For single Message Objects (not belonging to a FIFO Buffer), this bit must always be set to one.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [6:4] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [3:0] | <b>DLC</b>      | <p><b>Data Length Code</b></p> <p>0-8: Data Frame has 0-8 data bytes.<br/>     9-15: Data Frame has 8 data bytes</p> <p><b>Note:</b> The Data Length Code of a Message Object must be defined the same as in all the corresponding objects with the same identifier at other nodes. When the Message Handler stores a data frame, it will write the DLC to the value given by the received message.</p> <p>Data(0): 1st data byte of a CAN Data Frame<br/>     Data(1): 2nd data byte of a CAN Data Frame<br/>     Data(2): 3rd data byte of a CAN Data Frame<br/>     Data(3): 4th data byte of a CAN Data Frame<br/>     Data(4): 5th data byte of a CAN Data Frame<br/>     Data(5): 6th data byte of a CAN Data Frame<br/>     Data(6): 7th data byte of a CAN Data Frame<br/>     Data(7): 8th data byte of a CAN Data Frame</p> <p><b>Note:</b> The Data(0) byte is the first data byte shifted into the shift register of the CAN Core during a reception while the Data(7) byte is the last. When the Message Handler stores a Data Frame, it will write all the eight data bytes into a Message Object. If the Data Length Code is less than 8, the remaining bytes of the Message Object will be overwritten by unspecified values.</p> |

IFn Data A1 Register (CAN\_IFn\_DAT\_A1)

| Register       | Offset                      | R/W | Description                                 |  |  |  | Reset Value |
|----------------|-----------------------------|-----|---------------------------------------------|--|--|--|-------------|
| CAN_IFn_DAT_A1 | CAN_BA+0x3C + (0x60 *(n-1)) | R/W | IFn Data A1 Registers (Register Map Note 3) |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                         |
|---------|-------------|---------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                               |
| [15:8]  | Data(1)     | <b>Data Byte 1</b><br>2nd data byte of a CAN Data Frame |
| [7:0]   | Data(0)     | <b>Data Byte 0</b><br>1st data byte of a CAN Data Frame |

**IFn Data A2 Register (CAN\_IFn\_DAT\_A2)**

| Register       | Offset                         | R/W | Description                                 |  |  |  | Reset Value |
|----------------|--------------------------------|-----|---------------------------------------------|--|--|--|-------------|
| CAN_IFn_DAT_A2 | CAN_BA+0x40 +<br>(0x60 *(n-1)) | R/W | IFn Data A2 Registers (Register Map Note 3) |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                       |
|---------|-------------|-------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                             |
| [15:8]  | Data(3)     | <b>Data Byte 3</b><br>4th data byte of CAN Data Frame |
| [7:0]   | Data(2)     | <b>Data Byte 2</b><br>3rd data byte of CAN Data Frame |

**IFn Data B1 Register (CAN\_IFn\_DAT\_B1)**

| Register       | Offset                      | R/W | Description                                 |  |  |  | Reset Value |
|----------------|-----------------------------|-----|---------------------------------------------|--|--|--|-------------|
| CAN_IFn_DAT_B1 | CAN_BA+0x44 + (0x60 *(n-1)) | R/W | IFn Data B1 Registers (Register Map Note 3) |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                       |
|---------|-------------|-------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                             |
| [15:8]  | Data(5)     | <b>Data Byte 5</b><br>6th data byte of CAN Data Frame |
| [7:0]   | Data(4)     | <b>Data Byte 4</b><br>5th data byte of CAN Data Frame |

**IFn Data B2 Register (CAN\_IFn\_DAT\_B2)**

| Register       | Offset                      | R/W | Description                                 |  |  |  | Reset Value |
|----------------|-----------------------------|-----|---------------------------------------------|--|--|--|-------------|
| CAN_IFn_DAT_B2 | CAN_BA+0x48 + (0x60 *(n-1)) | R/W | IFn Data B2 Registers (Register Map Note 3) |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                        |
|---------|-------------|--------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                              |
| [15:8]  | Data(7)     | <b>Data Byte 7</b><br>8th data byte of CAN Data Frame. |
| [7:0]   | Data(6)     | <b>Data Byte 6</b><br>7th data byte of CAN Data Frame. |

In a CAN Data Frame, Data [0] is the first, Data [7] is the last byte to be transmitted or received. In CAN's serial bit stream, the MSB of each byte will be transmitted first.

### Message Object in the Message Memory

There are 32 Message Objects in the Message RAM. To avoid conflicts between application software access to the Message RAM and CAN message reception and transmission, the CPU cannot directly access the Message Objects, these accesses are handled through the IFn Interface Registers. Table 6.27-8 provides an overview of the structures of a Message Object.

| Message Object |            |      |      |           |         |         |         |         |         |         |         |         |
|----------------|------------|------|------|-----------|---------|---------|---------|---------|---------|---------|---------|---------|
| UMask          | Msk [28:0] | MXtd | MDir | EoB       | NewDat  |         | MsgLst  | RxIE    | TxIE    | IntPnd  | RmtEn   | TxRqst  |
| MsgVal         | ID [28:0]  | Xtd  | Dir  | DLC [3:0] | Data(0) | Data(1) | Data(2) | Data(3) | Data(4) | Data(5) | Data(6) | Data(7) |

Table 6.27-8 Structure of a Message Object in the Message Memory

The Arbitration Registers ID28-0 (CAN\_IFn\_ARB1/2), Xtd (CAN\_IFn\_ARB2[14]) and Dir (CAN\_IFn\_ARB2[13]) are used to define the identifier and type of outgoing messages and are used (together with the mask registers Msk28-0 (CAN\_IFn\_MASK1/2), MXtd (CAN\_IFn\_MASK2[15]) and MDir (CAN\_IFn\_MASK2[14])) for acceptance filtering of incoming messages. A received message is stored in the valid Message Object with matching identifier and Direction = receive (Data Frame) or Direction = transmit (Remote Frame). Extended frames can be stored only in Message Objects with Xtd = one, standard frames in Message Objects with Xtd = zero. If a received message (Data Frame or Remote Frame) matches with more than one valid Message Object, it is stored into that with the lowest message number.

### Message Handler Registers

All Message Handler registers are read only. Their contents (TxRqst (CAN\_IFn\_MCON[8]), NewDat (CAN\_IFn\_MCON[15]), IntPnd (CAN\_IFn\_MCON[13]) and MsgVal (CAN\_IFn\_ARB2[15]) bits of each Message Object and the Interrupt Identifier) are status information provided by the Message Handler FSM.

**Transmission Request Register 1 (CAN\_TXREQ1)**

These registers hold the TxRqst bits of the 32 Message Objects. By reading the TxRqst bits, the software can check which Message Object in a Transmission Request is pending. The TxRqst bit of a specific Message Object can be set/reset by the application software through the IFn Message Interface Registers or by the Message Handler after reception of a Remote Frame or after a successful transmission.

| Register   | Offset       | R/W | Description                     |  |  |  |  | Reset Value |
|------------|--------------|-----|---------------------------------|--|--|--|--|-------------|
| CAN_TXREQ1 | CAN_BA+0x100 | R   | Transmission Request Register 1 |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                               |
| [15:0]  | TxRqst16-1  | <b>Transmission Request Bits 16-1 (of All Message Objects) (Read Only)</b><br>0 = This Message Object is not waiting for transmission.<br>1 = The transmission of this Message Object is requested and is not yet done. |

Transmission Request Register 2 (CAN\_TXREQ2)

| Register   | Offset       | R/W | Description                     |  |  |  |  | Reset Value |
|------------|--------------|-----|---------------------------------|--|--|--|--|-------------|
| CAN_TXREQ2 | CAN_BA+0x104 | R   | Transmission Request Register 2 |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                |
| [15:0]  | TxRqst32-17 | <b>Transmission Request Bits 32-17 (of All Message Objects) (Read Only)</b><br>0 = This Message Object is not waiting for transmission.<br>1 = The transmission of this Message Object is requested and is not yet done. |

**New Data Register 1 (CAN\_NDAT1)**

These registers hold the NewDat bits of the 32 Message Objects. By reading out the NewDat bits, the software can check for which Message Object the data portion was updated. The NewDat bit of a specific Message Object can be set/reset by the software through the IFn Message Interface Registers or by the Message Handler after reception of a Data Frame or after a successful transmission.

| Register  | Offset       | R/W | Description         |  |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------|--|--|--|--|-------------|
| CAN_NDAT1 | CAN_BA+0x120 | R   | New Data Register 1 |  |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                   |
| [15:0]  | NewData16-1 | <b>New Data Bits 16-1 (of All Message Objects)</b><br>0 = No new data has been written into the data portion of this Message Object by the Message Handler since the last time this flag was cleared by the application software.<br>1 = The Message Handler or the application software has written new data into the data portion of this Message Object. |

**New Data Register 2 (CAN\_NDAT2)**

| Register  | Offset       | R/W | Description         |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------|--|--|--|-------------|
| CAN_NDAT2 | CAN_BA+0x124 | R   | New Data Register 2 |  |  |  | 0x0000_0000 |

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

| Bits    | Description  |                                                                                                                                                                                                                                                                                                                                                                             |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                   |
| [15:0]  | NewData32-17 | <p><b>New Data Bits 32-17 (of All Message Objects)</b></p> <p>0 = No new data has been written into the data portion of this Message Object by the Message Handler since the last time this flag was cleared by the application software.</p> <p>1 = The Message Handler or the application software has written new data into the data portion of this Message Object.</p> |

**Interrupt Pending Register 1 (CAN\_IPND1)**

These registers contain the IntPnd bits of the 32 Message Objects. By reading the IntPnd bits, the software can check for which Message Object an interrupt is pending. The IntPnd bit of a specific Message Object can be set/reset by the application software through the IFn Message Interface Registers or by the Message Handler after reception or after a successful transmission of a frame. This will also affect the value of IntId in the Interrupt Register.

| Register  | Offset       | R/W | Description                  |  |  |  |  | Reset Value |
|-----------|--------------|-----|------------------------------|--|--|--|--|-------------|
| CAN_IPND1 | CAN_BA+0x140 | R   | Interrupt Pending Register 1 |  |  |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                     |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                           |
| [15:0]  | IntPnd16-1  | <b>Interrupt Pending Bits 16-1 (of All Message Objects)</b><br>0 = This message object is not the source of an interrupt.<br>1 = This message object is the source of an interrupt. |

**Interrupt Pending Register 2 (CAN\_IPND2)**

| Register  | Offset       | R/W | Description                  |  |  |  |  | Reset Value |
|-----------|--------------|-----|------------------------------|--|--|--|--|-------------|
| CAN_IPND2 | CAN_BA+0x144 | R   | Interrupt Pending Register 2 |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                            |
| [15:0]  | IntPnd32-17 | <b>Interrupt Pending Bits 32-17 (of All Message Objects)</b><br>0 = This message object is not the source of an interrupt.<br>1 = This message object is the source of an interrupt. |

**Message Valid Register 1 (CAN\_MVLD1)**

These registers hold the MsgVal bits of the 32 Message Objects. By reading the MsgVal bits, the application software can check which Message Object is valid. The MsgVal bit of a specific Message Object can be set/reset by the application software via the IFn Message Interface Registers.

| Register  | Offset       | R/W | Description              |  |  |  |  | Reset Value |
|-----------|--------------|-----|--------------------------|--|--|--|--|-------------|
| CAN_MVLD1 | CAN_BA+0x160 | R   | Message Valid Register 1 |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [15:0]  | MsgVal16-1  | <b>Message Valid Bits 16-1 (of All Message Objects) (Read Only)</b><br>0 = This Message Object is ignored by the Message Handler.<br>1 = This Message Object is configured and should be considered by the Message Handler.<br><b>Note:</b> CAN_MVLD1[0] means Message object No.1 is valid or not. If CAN_MVLD1[0] is set, message object No.1 is configured. |

**Message Valid Register 2 (CAN\_MVLD2)**

| Register  | Offset       | R/W | Description              |  |  |  | Reset Value |
|-----------|--------------|-----|--------------------------|--|--|--|-------------|
| CAN_MVLD2 | CAN_BA+0x164 | R   | Message Valid Register 2 |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                              |
| [15:0]  | MsgVal32-17 | <p><b>Message Valid Bits 32-17 (of All Message Objects) (Read Only)</b></p> <p>0 = This Message Object is ignored by the Message Handler.</p> <p>1 = This Message Object is configured and should be considered by the Message Handler.</p> <p><b>Note:</b> CAN_MVLD2[15] means Message object No.32 is valid or not. If CAN_MVLD2[15] is set, message object No.32 is configured.</p> |

**Wake-up Enable Control Register (CAN\_WU\_EN)**

| Register  | Offset       | R/W | Description                     |  |  |  |  | Reset Value |
|-----------|--------------|-----|---------------------------------|--|--|--|--|-------------|
| CAN_WU_EN | CAN_BA+0x168 | R/W | Wake-up Enable Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                              |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                    |
| [0]    | WAKUP_EN    | <p><b>Wake-up Enable Bit</b></p> <p>0 = The wake-up function Disabled.<br/>1 = The wake-up function Enabled.</p> <p><b>Note:</b> User can wake up system when there is a falling edge in the CAN_Rx pin.</p> |

**Wake-up Status Register (CAN\_WU\_STATUS)**

| Register      | Offset       | R/W | Description             |  |  |  |  | Reset Value |
|---------------|--------------|-----|-------------------------|--|--|--|--|-------------|
| CAN_WU_STATUS | CAN_BA+0x16C | R/W | Wake-up Status Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                      |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                            |
| [0]    | WAKUP_STS   | <p><b>Wake-up Status</b></p> <p>0 = No wake-up event occurred.<br/>1 = Wake-up event occurred.</p> <p><b>Note:</b> This bit can be cleared by writing '0' to it.</p> |

## 6.28 Secure Digital Host Controller (SDH)

### 6.28.1 Overview

The Secure Digital Host Controller (SD Host) has DMAC unit and SD unit. The DMAC unit provides a DMA (Direct Memory Access) function for SD to exchange data between system memory and shared buffer (128 bytes), and the SD unit controls the interface of SD/SDHC. The SDHOST controller can support SD/SDHC and cooperated with DMAC to provide a fast data transfer between system memory and cards.

### 6.28.2 Features

- AMBA AHB master/slave interface compatible, for data transfer and register read/write.
- Supports single DMA channel.
- Supports hardware Scatter-Gather function.
- Using single 128 Bytes shared buffer for data exchange between system memory and cards.
- Synchronous design for DMA with single clock domain, AHB bus clock (HCLK).
- Interface with DMAC for register read/write and data transfer.
- Supports SD/SDHC card.
- Completely asynchronous design for Secure Digital with two clock domains, HCLK and Engine clock, note that frequency of HCLK should be higher than the frequency of peripheral clock.

### 6.28.3 Block Diagram

The block diagram and Card Pad Assignment of SDHOST Controller is shown as follows.



Figure 6.28-1 SD Host Controller Block Diagram

### 6.28.4 Basic Configuration

#### 6.28.4.1 SD0 Basic Configuration

- Clock source Configuration
  - Select the source of SD0 engine clock on SDH0SEL (CLK\_CLKSEL0[21:20]).
  - Select the clock divider number of SD0 engine clock on SDH0DIV (CLK\_CLKDIV0[31:24]).
  - Enable SD0 engine clock in SDH0CKEN (CLK\_AHBCLK[6]).
- Reset Configuration
  - Reset SD0 controller in SDH0RST (SYS\_IPRST0[6]).
- Pin Configuration

| Group | Pin Name | GPIO       | MFP  |
|-------|----------|------------|------|
| SD0   | SD0_CLK  | PB.1, PE.6 | MFP3 |
|       | SD0_CMD  | PB.0, PE.7 | MFP3 |
|       | SD0_DAT0 | PB.2, PE.2 | MFP3 |
|       | SD0_DAT1 | PB.3, PE.3 | MFP3 |

|  |          |            |      |
|--|----------|------------|------|
|  | SD0_DAT2 | PB.4, PE.4 | MFP3 |
|  | SD0_DAT3 | PB.5, PE.5 | MFP3 |
|  | SD0_nCD  | PD.13      | MFP3 |
|  |          | PB.12      | MFP9 |

Table 6.28-1 SD0 Pin Configuration

#### 6.28.4.2 SD1 Basic Configuration

- Clock source Configuration
  - Select the source of SD1 engine clock on SDH1SEL (CLK\_CLKSEL0[23:22]).
  - Select the clock divider number of SD1 engine clock on SDH1DIV (CLK\_CLKDIV3[31:24]).
  - Enable SD1 engine clock in SDH1CKEN (CLK\_AHBCLK[17]).
- Reset Configuration
  - Reset SD1 controller in SDH1RST (SYS\_IPRST0[17]).
- Pin Configuration

| Group | Pin Name | GPIO        | MFP  |
|-------|----------|-------------|------|
| SD1   | SD1_CLK  | PG.14       | MFP3 |
|       |          | PA.4        | MFP5 |
|       |          | PB.6        | MFP7 |
|       | SD1_CMD  | PG.13       | MFP3 |
|       |          | PA.5        | MFP5 |
|       |          | PB.7        | MFP7 |
|       | SD1_DAT0 | PG.12       | MFP3 |
|       |          | PA.0, PA.8  | MFP5 |
|       | SD1_DAT1 | PG.11       | MFP3 |
|       |          | PA.1, PA.9  | MFP5 |
|       | SD1_DAT2 | PG.10       | MFP3 |
|       |          | PA.2, PA.10 | MFP5 |
|       | SD1_DAT3 | PG.9        | MFP3 |
|       |          | PA.3, PA.11 | MFP5 |
|       | SD1_nCD  | PG.15       | MFP3 |
|       |          | PA.6, PE.14 | MFP5 |

Table 6.28-2 SD1 Pin Configuration

#### 6.28.5 Functional Description

The SD host provides an interface for SD/SDHC card access with 1-bit/4-bit data bus width.

The SD controller uses an independent clock source named SDCLK as engine clock. SDCLK can be completely asynchronous with system clock HCLK, software can change SD clock arbitrary. However,

HCLK should be faster than SDCLK.

#### 6.28.5.1 Basic Operation

This SD controller can generate all types of 48-bit command to SD card and retrieve all types of response from SD card. After response in, the content of response will be stored at SDRSP0 and SDRSP1. SD controller will calculate CRC7 and check its correctness for response. If CRC7 is error, CDRIF (SDH\_INTSTS[1]) will be set and CRC7 (SDH\_INTSTS[2]) will be '0'. For response R1b, software should notice that after response in, SD card will put busy signal on data line DAT0; software should check this status with clock polling until it became high. For response R3, CRC7 is invalid; but SD controller will still calculate CRC7 and get an error result, software should ignore this error and clear CDRIF flag (SDH\_INTSTS[1]).

The SD controller is composed of two state machines – command/response part and data part. For command/response part, the trigger bits are COEN, RIEN, R2\_EN, CLK74OE and CLK8\_OE in SDH\_CTL register. If software enables all of these bits, the execution priority will be CLK74OE > COEN > RIEN/R2\_EN > CLK8\_OE, note that RIEN and R2\_EN can't be triggered at the same time. For data part, there are DIEN and DOEN for choose. Software can only trigger one of them at one time. If DIEN is triggered, SD controller waits start bit from data line DAT0 immediately, and then get specified amount data from SD card. After data-in, SD controller will check CRC16 correctness; if it is error, CDRIF (SDH\_INTSTS[1]) will be set and CRC16 (SDH\_INTSTS[3]) will be '0'. If DOEN is triggered, SD controller will wait response in finished, and then send specified amount data to SD card. After data-out, SD controller will get CRC status from SD card and check its correctness; it should be '010', otherwise CDRIF (SDH\_INTSTS[1]) will be set and CRCSTAT (SDH\_INTSTS[6:4]) will be the value it received.

If R2\_EN is triggered, SD controller will receive response R2 (136 bits) from SD card, CRC7 and end bit will be dropped. The receiving data will be placed at DMA's buffer, starting from address offset 0x0.

#### 6.28.5.2 Multiple Block Transfer

The SD controller also provides multiple block transfer function (change BLKLEN to change the block length). Software can use this function to accelerate data transfer throughput. If CRC7, CRC16 or CRC status is error, SD controller will stop transfer and set CDRIF (SDH\_INTSTS[1]), software should do engine reset when this situation occurred.

There is a hardware time-out mechanism for response in and data in inside SD engine. Software can specify a 24-bit time-out value at TOUT, and then SD controller will decide when to time-out according to this value.

#### 6.28.5.3 DMA Controller

The SD host DMA controller provides a DMA (Direct Memory Access) function for SD host controller to exchange data between system memory (SRAM) and shared buffer (128 bytes). Arbitration of DMA request between SD host is done by DMA's bus master. Software just simply fills in the starting address and enables DMA, and then let DMA to handle the data transfer automatically.

There is a 128 bytes shared buffer inside DMA, it can provide multi-block transfers for SD host. Software can access these shared buffers directly when SD host is not in busy.

#### 6.28.5.4 Programming Flow

**Here is a simple example programming flow without DMA Scatter-Gather enable.**

1. Set DMAEN (SDH\_DMACTL[0]) to enable DMA.
2. Fill corresponding starting address in SDH\_DMASA for SD host.
3. Trigger SD host to start DMA transfer.
4. Wait until transfer is finished.

**Here is a simple example programming flow with DMA Scatter-Gather enable.**

1. Set DMAEN (SDH\_DMACTL[0]) to enable DMA (SDH\_DMACTL[0]) and SGEN (SDH\_DMACTL[3]) to enable Scatter-Gather function.

2. Fill corresponding starting address of Physical Address Descriptor (PAD) table in SDH\_DMASA for SD host.
3. When bit-0 of SDH\_DMASA is 1, the PAD will fetch in out of order, otherwise, it's fetched in order from PAD. The first time of writing bit-0 with 1 or not is not available for this function. The bits will be available in PAD table.
4. Trigger SD host to start DMA transfer.
5. Wait until transfer is finished.

The format of PAD table is shown in Figure 6.28-2. Note that the total byte count of all Pads must be equal to the byte count filled in SD host. EOT should be set to 1 in the last descriptor.



Figure 6.28-2 PAD (Physical Address Descriptor) Table Format

### 6.28.6 Register Map

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

| Register                                  | Offset                  | R/W | Description                            | Reset Value |
|-------------------------------------------|-------------------------|-----|----------------------------------------|-------------|
| <b>SDH Base address:</b>                  |                         |     |                                        |             |
| <b>SDH0_BA = 0x4000_D000</b>              |                         |     |                                        |             |
| <b>SDH1_BA = 0x4000_E000</b>              |                         |     |                                        |             |
| <b>SDH_FB_n</b><br><br>x=0,1<br>n=0,1..31 | SDHx_BA+0x000 + 0x4 * n | R/W | Shared Buffer (FIFO)                   | 0x0000_0000 |
| <b>SDH_DMACTL</b><br><br>x=0,1            | SDHx_BA+0x400           | R/W | DMA Control and Status Register        | 0x0000_0000 |
| <b>SDH_DMASA</b><br><br>x=0,1             | SDHx_BA+0x408           | R/W | DMA Transfer Starting Address Register | 0x0000_0000 |
| <b>SDH_DMABCNT</b><br><br>x=0,1           | SDHx_BA+0x40C           | R   | DMA Transfer Byte Count Register       | 0x0000_0000 |
| <b>SDH_DMAINTEN</b><br><br>x=0,1          | SDHx_BA+0x410           | R/W | DMA Interrupt Enable Control Register  | 0x0000_0001 |
| <b>SDH_DMAINTSTS</b><br><br>x=0,1         | SDHx_BA+0x414           | R/W | DMA Interrupt Status Register          | 0x0000_0000 |
| <b>SDH_GCTL</b><br><br>x=0,1              | SDHx_BA+0x800           | R/W | Global Control and Status Register     | 0x0000_0000 |
| <b>SDH_GINTEN</b><br><br>x=0,1            | SDHx_BA+0x804           | R/W | Global Interrupt Control Register      | 0x0000_0001 |
| <b>SDH_GINTSTS</b><br><br>x=0,1           | SDHx_BA+0x808           | R/W | Global Interrupt Status Register       | 0x0000_0000 |
| <b>SDH_CTL</b><br><br>x=0,1               | SDHx_BA+0x820           | R/W | SD Control and Status Register         | 0x0101_0000 |
| <b>SDH_CMDARG</b><br><br>x=0,1            | SDHx_BA+0x824           | R/W | SD Command Argument Register           | 0x0000_0000 |
| <b>SDH_INTEN</b><br><br>x=0,1             | SDHx_BA+0x828           | R/W | SD Interrupt Control Register          | 0x0000_0A00 |
| <b>SDH_INTSTS</b><br><br>x=0,1            | SDHx_BA+0x82C           | R/W | SD Interrupt Status Register           | 0x000X_008C |
| <b>SDH_RESP0</b><br><br>x=0,1             | SDHx_BA+0x830           | R   | SD Receiving Response Token Register 0 | 0x0000_0000 |
| <b>SDH_RESP1</b><br><br>x=0,1             | SDHx_BA+0x834           | R   | SD Receiving Response Token Register 1 | 0x0000_0000 |
| <b>SDH_BLEN</b><br><br>x=0,1              | SDHx_BA+0x838           | R/W | SD Block Length Register               | 0x0000_01FF |
| <b>SDH_TOUT</b><br><br>x=0,1              | SDHx_BA+0x83C           | R/W | SD Response/Data-in Time-out Register  | 0x0000_0000 |

### 6.28.7 Register Description

#### DMA Control and Status Register (SDH\_DMACTL)

| Register   | Offset        | R/W | Description                     |  |  |  | Reset Value |
|------------|---------------|-----|---------------------------------|--|--|--|-------------|
| SDH_DMACTL | SDHx_BA+0x400 | R/W | DMA Control and Status Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                   |
| [9]     | DMABUSY     | <b>DMA Transfer Is in Progress</b><br>This bit indicates if SD Host is granted and doing DMA transfer or not.<br>0 = DMA transfer is not in progress.<br>1 = DMA transfer is in progress.                                                                                                                                                                                                   |
| [8:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                   |
| [3]     | SGEN        | <b>Scatter-gather Function Enable Bit</b><br>0 = Scatter-gather function Disabled (DMA will treat the starting address in DMASAR as starting pointer of a single block memory).<br>1 = Scatter-gather function Enabled (DMA will treat the starting address in DMASAR as a starting address of Physical Address Descriptor (PAD) table. The format of these Pads' will be described later). |
| [2]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                   |
| [1]     | DMARST      | <b>Software Engine Reset</b><br>0 = No effect.<br>1 = Reset internal state machine and pointers. The contents of control register will not be cleared. This bit will auto be cleared after few clock cycles.<br><b>Note:</b> The software reset DMA related registers.                                                                                                                      |
| [0]     | DMAEN       | <b>DMA Engine Enable Bit</b><br>0 = DMA Disabled.<br>1 = DMA Enabled.<br><b>Note1:</b> If this bit is cleared, DMA will ignore all requests from SD host and force bus master into IDLE state.<br><b>Note2:</b> If target abort occurred, DMAEN will be cleared.                                                                                                                            |

**DMA Transfer Starting Address Register (SDH\_DMASA)**

| Register  | Offset        | R/W | Description                            |  |  |  |  | Reset Value |
|-----------|---------------|-----|----------------------------------------|--|--|--|--|-------------|
| SDH_DMASA | SDHx_BA+0x408 | R/W | DMA Transfer Starting Address Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | DMASA       | <p><b>DMA Transfer Starting Address</b><br/>           This field pads 0 as least significant bit indicates a 32-bit starting address of system memory (SRAM) for DMA to retrieve or fill in data.<br/>           If DMA is not in normal mode, this field will be interpreted as a starting address of Physical Address Descriptor (PAD) table.<br/> <b>Note:</b> Starting address of the SRAM must be word aligned, for example, 0x0000_0000, 0x0000_0004.</p> |
| [0]    | ORDER       | <p><b>Determined to the PAD Table Fetching Is in Order or Out of Order</b><br/>           0 = PAD table is fetched in order.<br/>           1 = PAD table is fetched out of order.<br/> <b>Note:</b> the bit0 is valid in scatter-gather mode when SGEN = 1.</p>                                                                                                                                                                                                 |

DMA Transfer Byte Count Register (SDH\_DMABCNT)

| Register    | Offset        | R/W | Description                      |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------------|--|--|--|-------------|
| SDH_DMABCNT | SDHx_BA+0x40C | R   | DMA Transfer Byte Count Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                         |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | <b>Reserved</b> | Reserved.                                                                                                                                                                               |
| [25:0]  | <b>BCNT</b>     | <b>DMA Transfer Byte Count (Read Only)</b><br>This field indicates the remained byte count of DMA transfer. The value of this field is valid only when DMA is busy; otherwise, it is 0. |

**DMA Interrupt Enable Control Register (SDH\_DMAINTEN)**

| Register     | Offset        | R/W | Description                           |  |  |  | Reset Value |
|--------------|---------------|-----|---------------------------------------|--|--|--|-------------|
| SDH_DMAINTEN | SDHx_BA+0x410 | R/W | DMA Interrupt Enable Control Register |  |  |  | 0x0000_0001 |

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

| Bits   | Description |                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                            |
| [1]    | WEOTIEN     | <b>Wrong EOT Encountered Interrupt Enable Bit</b><br>0 = Interrupt generation Disabled when wrong EOT is encountered.<br>1 = Interrupt generation Enabled when wrong EOT is encountered.             |
| [0]    | ABORTIEN    | <b>DMA Read/Write Target Abort Interrupt Enable Bit</b><br>0 = Target abort interrupt generation Disabled during DMA transfer.<br>1 = Target abort interrupt generation Enabled during DMA transfer. |

**DMA Interrupt Status Register (SDH DMAINTSTS)**

| Register      | Offset        | R/W | Description                   |  |  |  | Reset Value |
|---------------|---------------|-----|-------------------------------|--|--|--|-------------|
| SDH_DMAINTSTS | SDHx_BA+0x414 | R/W | DMA 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 |    |    |    |    |    | WEOTIF | ABORTIF |

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [1]    | <b>WEOTIF</b>   | <p><b>Wrong EOT Encountered Interrupt Flag (Read Only)</b><br/> When DMA Scatter-Gather function is enabled, and EOT of the descriptor is encountered before DMA transfer finished (that means the total sector count of all PAD is less than the sector count of SD host), this bit will be set.<br/> 0 = No EOT encountered before DMA transfer finished.<br/> 1 = EOT encountered before DMA transfer finished.</p> <p><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.</p>                                          |
| [0]    | <b>ABORTIF</b>  | <p><b>DMA Read/Write Target Abort Interrupt Flag (Read Only)</b><br/> 0 = No bus ERROR response received.<br/> 1 = Bus ERROR response received.</p> <p><b>Note1:</b> This bit is read only, but can be cleared by writing '1' to it.</p> <p><b>Note2:</b> When DMA's bus master received ERROR response, it means that target abort is happened. DMA will stop transfer and respond this event and then go to IDLE state. When target abort occurred or WEOTIF is set, software must reset DMA and SD host, and then transfer those data again.</p> |

Global Control and Status Register (SDH\_GCTL)

| Register | Offset        | R/W | Description                        |  |  |  |  | Reset Value |
|----------|---------------|-----|------------------------------------|--|--|--|--|-------------|
| SDH_GCTL | SDHx_BA+0x800 | R/W | Global Control and Status Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                   |
| [1]    | SDEN        | <b>Secure Digital Functionality Enable Bit</b><br>0 = SD functionality Disabled.<br>1 = SD functionality Enabled.                                                           |
| [0]    | GCTRLRST    | <b>Software Engine Reset</b><br>0 = No effect.<br>1 = Reset SD host. The contents of control register will not be cleared. This bit will auto cleared after reset complete. |

**Global Interrupt Control Register (SDH\_GINTEN)**

| Register   | Offset        | R/W | Description                       |  |  |  |  | Reset Value |
|------------|---------------|-----|-----------------------------------|--|--|--|--|-------------|
| SDH_GINTEN | SDHx_BA+0x804 | R/W | Global Interrupt Control Register |  |  |  |  | 0x0000_0001 |

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

| Bits   | Description     |                                                                                                                                                                                            |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | <b>Reserved</b> | Reserved.                                                                                                                                                                                  |
| [0]    | <b>DTAIEN</b>   | <b>DMA READ/WRITE Target Abort Interrupt Enable Bit</b><br>0 = DMA READ/WRITE target abort interrupt generation Disabled.<br>1 = DMA READ/WRITE target abort interrupt generation Enabled. |

Global Interrupt Status Register (SDH\_GINTSTS)

| Register    | Offset        | R/W | Description                      |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------------|--|--|--|-------------|
| SDH_GINTSTS | SDHx_BA+0x808 | R/W | Global 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 |    |    |    |    |    |    | DTAIF |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                        |
| [0]    | DTAIF       | <p><b>DMA READ/WRITE Target Abort Interrupt Flag (Read Only)</b></p> <p>This bit indicates DMA received an ERROR response from internal AHB bus during DMA read/write operation. When Target Abort is occurred, please reset all engine.</p> <p>0 = No bus ERROR response received.<br/>1 = Bus ERROR response received.</p> <p><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.</p> |

**SD Control and Status Register (SDH\_CTL)**

| Register | Offset        | R/W | Description                    |  |  |  | Reset Value |
|----------|---------------|-----|--------------------------------|--|--|--|-------------|
| SDH_CTL  | SDHx_BA+0x820 | R/W | SD Control and Status Register |  |  |  | 0x0101_0000 |

|          |         |          |      |       |      |      |      |
|----------|---------|----------|------|-------|------|------|------|
| 31       | 30      | 29       | 28   | 27    | 26   | 25   | 24   |
| Reserved |         |          |      | SDNWR |      |      |      |
| 23       | 22      | 21       | 20   | 19    | 18   | 17   | 16   |
| BLKCNT   |         |          |      |       |      |      |      |
| 15       | 14      | 13       | 12   | 11    | 10   | 9    | 8    |
| DBW      | CTLRST  | CMDCODE  |      |       |      |      |      |
| 7        | 6       | 5        | 4    | 3     | 2    | 1    | 0    |
| CLKKEEP  | CLK8OEN | CLK74OEN | R2EN | DOEN  | DIEN | RIEN | COEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [27:24] | SDNWR       | <b>NWR Parameter for Block Write Operation</b><br>This value indicates the NWR parameter for data block write operation in SD clock counts. The actual clock cycle will be SDNWR+1.                                                                                                                                                                                                                                                 |
| [23:16] | BLKCNT      | <b>Block Counts to Be Transferred or Received</b><br>This field contains the block counts for data-in and data-out transfer. For READ_MULTIPLE_BLOCK and WRITE_MULTIPLE_BLOCK command, software can use this function to accelerate data transfer and improve performance. Don't fill 0x0 to this field.<br><b>Note:</b> For READ_MULTIPLE_BLOCK and WRITE_MULTIPLE_BLOCK command, the actual total length is BLKCNT * (BLKLEN +1). |
| [15]    | DBW         | <b>SD Data Bus Width (for 1-bit / 4-bit Selection)</b><br>0 = Data bus width is 1-bit.<br>1 = Data bus width is 4-bit.                                                                                                                                                                                                                                                                                                              |
| [14]    | CTLRST      | <b>Software Engine Reset</b><br>0 = No effect.<br>1 = Reset the internal state machine and counters. The contents of control register will not be cleared (but RIEN, DIEN, DOEN and R2_EN will be cleared). This bit will be auto cleared after few clock cycles.                                                                                                                                                                   |
| [13:8]  | CMDCODE     | <b>SD Command Code</b><br>The bits contain the SD command code (0x00 – 0x3F).                                                                                                                                                                                                                                                                                                                                                       |
| [7]     | CLKKEEP     | <b>SD Clock Enable Control</b><br>0 = SD host decided when to output clock and when to disable clock output automatically.<br>1 = SD clock always keeps free running.                                                                                                                                                                                                                                                               |

|     |                 |                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | <b>CLK8OEN</b>  | <b>Generating 8 Clock Cycles Output Enable Bit</b><br>0 = No effect. (Please use DMARST (SDH_CTL [0]) to clear this bit.)<br>1 = Enabled. The SD host will output 8 clock cycles.<br><b>Note:</b> When operation is finished, this bit will be cleared automatically, so don't write 0 to this bit (the controller will be abnormal).                                                                          |
| [5] | <b>CLK74OEN</b> | <b>Initial 74 Clock Cycles Output Enable Bit</b><br>0 = No effect. (Please use DMARST (SDH_CTL [0]) to clear this bit.)<br>1 = Enabled. The SD host will output 74 clock cycles to SD card.<br><b>Note:</b> When operation is finished, this bit will be cleared automatically, so don't write 0 to this bit (the controller will be abnormal).                                                                |
| [4] | <b>R2EN</b>     | <b>Response R2 Input Enable Bit</b><br>0 = No effect. (Please use DMARST (SDH_CTL [0]) to clear this bit.)<br>1 = Enabled. The SD host will wait to receive a response R2 from SD card and store the response data into DMC's Flash buffer (exclude CRC7).<br><b>Note:</b> When operation is finished, this bit will be cleared automatically, so don't write 0 to this bit (the controller will be abnormal). |
| [3] | <b>DOEN</b>     | <b>Data Output Enable Bit</b><br>0 = No effect. (Please use DMARST (SDH_CTL [0]) to clear this bit.)<br>1 = Enabled. The SD host will transfer block data and the CRC16 value to SD card.<br><b>Note:</b> When operation is finished, this bit will be cleared automatically, so don't write 0 to this bit (the controller will be abnormal).                                                                  |
| [2] | <b>DIEN</b>     | <b>Data Input Enable Bit</b><br>0 = No effect. (Please use DMARST (SDH_CTL [0]) to clear this bit.)<br>1 = Enabled. The SD host will wait to receive block data and the CRC16 value from SD card.<br><b>Note:</b> When operation is finished, this bit will be cleared automatically, so don't write 0 to this bit (the controller will be abnormal).                                                          |
| [1] | <b>RIEN</b>     | <b>Response Input Enable Bit</b><br>0 = No effect. (Please use DMARST (SDH_CTL [0]) to clear this bit.)<br>1 = Enabled. The SD host will wait to receive a response from SD card.<br><b>Note:</b> When operation is finished, this bit will be cleared automatically, so don't write 0 to this bit (the controller will be abnormal).                                                                          |
| [0] | <b>COEN</b>     | <b>Command Output Enable Bit</b><br>0 = No effect. (Please use DMARST (SDH_CTL [0]) to clear this bit.)<br>1 = Enabled. The SD host will output a command to SD card.<br><b>Note:</b> When operation is finished, this bit will be cleared automatically, so don't write 0 to this bit (the controller will be abnormal).                                                                                      |

**SD Command Argument Register (SDH\_CMDARG)**

| Register   | Offset        | R/W | Description                  |  |  |  | Reset Value |
|------------|---------------|-----|------------------------------|--|--|--|-------------|
| SDH_CMDARG | SDHx_BA+0x824 | R/W | SD Command Argument Register |  |  |  | 0x0000_0000 |



| Bits   | Description     |                                                                                                                                                                                                                                      |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>ARGUMENT</b> | <p><b>SD Command Argument</b></p> <p>This register contains a 32-bit value specifies the argument of SD command from host controller to SD card. Before trigger COEN (SDH_CTL [0]), software should fill argument in this field.</p> |

**SD Interrupt Control Register (SDH\_INTEN)**

| Register  | Offset        | R/W | Description                   |  |  |  | Reset Value |
|-----------|---------------|-----|-------------------------------|--|--|--|-------------|
| SDH_INTEN | SDHx_BA+0x828 | R/W | SD Interrupt Control Register |  |  |  | 0x0000_0A00 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |
| [30]    | CDSRC       | <b>SD Card Detect Source Selection</b><br>0 = From SD card's DAT3 pin.<br>Host need clock to get data on pin DAT3. Please make sure CLKKEEP (SDH_CTL[7]) is 1 in order to generate free running clock for DAT3 pin.<br>1 = From GPIO pin.                                                                     |
| [29:15] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |
| [14]    | WKIEN       | <b>Wake-up Signal Generating Enable Bit</b><br>Enable/Disable wake-up signal generating of SD controller when card is inserted or removed.<br>0 = SD Card interrupt to wake-up chip Disabled.<br>1 = SD Card interrupt to wake-up chip Enabled.                                                               |
| [13]    | DITOIEN     | <b>Data Input Time-out Interrupt Enable Bit</b><br>Enable/Disable interrupts generation of SD controller when data input time-out. Time-out value is specified at TOUT register.<br>0 = DITOIF (SDH_INTEN[13]) trigger interrupt Disabled.<br>1 = DITOIF (SDH_INTEN[13]) trigger interrupt Enabled.           |
| [12]    | RTOIEN      | <b>Response Time-out Interrupt Enable Bit</b><br>Enable/Disable interrupts generation of SD controller when receiving response or R2 time-out. Time-out value is specified at TOUT register.<br>0 = RTOIF (SDH_INTEN[12]) trigger interrupt Disabled.<br>1 = RTOIF (SDH_INTEN[12]) trigger interrupt Enabled. |
| [11:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |
| [8]     | CDIEN       | <b>SD Card Detection Interrupt Enable Bit</b><br>Enable/Disable interrupts generation of SD controller when card is inserted or removed.<br>0 = CDIF (SDH_INTEN[8]) trigger interrupt Disable.<br>1 = CDIF (SDH_INTEN[8]) trigger interrupt Enabled.                                                          |

|       |                 |                                                                                                                                                                            |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                  |
| [1]   | <b>CRCIEN</b>   | <b>CRC7, CRC16 and CRC Status Error Interrupt Enable Bit</b><br>0 = CRCIF (SDH_INTEN[1]) trigger interrupt Disable.<br>1 = CRCIF (SDH_INTEN[1]) trigger interrupt Enabled. |
| [0]   | <b>BLKDIEN</b>  | <b>Block Transfer Done Interrupt Enable Bit</b><br>0 = BLKDIF (SDH_INTEN[0]) trigger interrupt Disable.<br>1 = BLKDIF (SDH_INTEN[0]) trigger interrupt Enabled.            |

**SD Interrupt Status Register (SDH\_INTSTS)**

| Register   | Offset        | R/W | Description                  |  |  | Reset Value |
|------------|---------------|-----|------------------------------|--|--|-------------|
| SDH_INTSTS | SDHx_BA+0x82C | R/W | SD Interrupt Status Register |  |  | 0x000X_008C |

|          |        |        |       |          |         |          |        |
|----------|--------|--------|-------|----------|---------|----------|--------|
| 31       | 30     | 29     | 28    | 27       | 26      | 25       | 24     |
| Reserved |        |        |       |          |         |          |        |
| 23       | 22     | 21     | 20    | 19       | 18      | 17       | 16     |
| Reserved |        |        |       |          | DAT1STS | Reserved | CDSTS  |
| 15       | 14     | 13     | 12    | 11       | 10      | 9        | 8      |
| Reserved |        | DITOIF | RTOIF | Reserved |         | Reserved | CDIF   |
| 7        | 6      | 5      | 4     | 3        | 2       | 1        | 0      |
| DAT0STS  | CRCSTS |        |       | CRC16    | CRC7    | CRCIF    | BLKDIF |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [18]    | DAT1STS     | <b>DAT1 Pin Status of SD Card (Read Only)</b><br>This bit indicates the DAT1 pin status of SD card.                                                                                                                                                                                                                                                                                                                                                                                                              |
| [17]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [16]    | CDSTS       | <b>Card Detect Status of SD (Read Only)</b><br>This bit indicates the card detect pin status of SD, and is used for card detection. When there is a card inserted in or removed from SD, software should check this bit to confirm if there is really a card insertion or removal.<br>If CDSRC (SDH_INTEN[30]) = 0, to select DAT3 for card detection:<br>0 = Card removed.<br>1 = Card inserted.<br>If CDSRC (SDH_INTEN[30]) = 1, to select GPIO for card detection:<br>0 = Card inserted.<br>1 = Card removed. |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [13]    | DITOIF      | <b>Data Input Time-out Interrupt Flag (Read Only)</b><br>This bit indicates that SD host counts to time-out value when receiving data (waiting start bit).<br>0 = Not time-out.<br>1 = Data input time-out.<br><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                      |
| [12]    | RTOIF       | <b>Response Time-out Interrupt Flag (Read Only)</b><br>This bit indicates that SD host counts to time-out value when receiving response or R2 (waiting start bit).<br>0 = Not time-out.<br>1 = Response time-out.<br><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                |

|        |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11:9] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [8]    | <b>CDIF</b>     | <p><b>SD Card Detection Interrupt Flag (Read Only)</b></p> <p>This bit indicates that SD card is inserted or removed. Only when CDIEN (SDH_INTEN[8]) is set to 1, this bit is active.</p> <p>0 = No card is inserted or removed.<br/>1 = There is a card inserted in or removed from SD.</p> <p><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.</p>                                                                                                                                                                                                                                                                      |
| [7]    | <b>DAT0STS</b>  | <p><b>DAT0 Pin Status of Current Selected SD Port (Read Only)</b></p> <p>This bit is the DAT0 pin status of current selected SD port.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [6:4]  | <b>CRCSTS</b>   | <p><b>CRC Status Value of Data-out Transfer (Read Only)</b></p> <p>SD host will record CRC status of data-out transfer. Software could use this value to identify what type of error is during data-out transfer.</p> <p>010 = Positive CRC status.<br/>101 = Negative CRC status.<br/>111 = SD card programming error occurs.</p>                                                                                                                                                                                                                                                                                                                    |
| [3]    | <b>CRC16</b>    | <p><b>CRC16 Check Status of Data-in Transfer (Read Only)</b></p> <p>SD host will check CRC16 correctness after data-in transfer.</p> <p>0 = Fault.<br/>1 = OK.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [2]    | <b>CRC7</b>     | <p><b>CRC7 Check Status (Read Only)</b></p> <p>SD host will check CRC7 correctness during each response in. If that response does not contain CRC7 information (ex. R3), then software should turn off CRCIEN (SDH_INTEN[1]) and ignore this bit.</p> <p>0 = Fault.<br/>1 = OK.</p>                                                                                                                                                                                                                                                                                                                                                                   |
| [1]    | <b>CRCIF</b>    | <p><b>CRC7, CRC16 and CRC Status Error Interrupt Flag (Read Only)</b></p> <p>This bit indicates that SD host has occurred CRC error during response in, data-in or data-out (CRC status error) transfer. When CRC error is occurred, software should reset SD engine. Some response (ex. R3) doesn't have CRC7 information with it; SD host will still calculate CRC7, get CRC error and set this flag. In this condition, software should ignore CRC error and clears this bit manually.</p> <p>0 = No CRC error is occurred.<br/>1 = CRC error is occurred.</p> <p><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.</p> |
| [0]    | <b>BLKDIF</b>   | <p><b>Block Transfer Done Interrupt Flag (Read Only)</b></p> <p>This bit indicates that SD host has finished all data-in or data-out block transfer. If there is a CRC16 error or incorrect CRC status during multiple block data transfer, the transfer will be broken and this bit will also be set.</p> <p>0 = Not finished yet.<br/>1 = Done.</p> <p><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.</p>                                                                                                                                                                                                             |

**SD Receiving Response Token Register 0 (SDH\_RESP0)**

| Register  | Offset        | R/W | Description                            | Reset Value |
|-----------|---------------|-----|----------------------------------------|-------------|
| SDH_RESP0 | SDHx_BA+0x830 | R   | SD Receiving Response Token Register 0 | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | RESPTK0     | SD Receiving Response Token 0<br>SD host controller will receive a response token for getting a reply from SD card when RIEN (SDH_CTL[1]) is set. This field contains response bit 47-16 of the response token. |

**SD Receiving Response Token Register 1 (SDH\_RESP1)**

| Register  | Offset        | R/W | Description                            | Reset Value |
|-----------|---------------|-----|----------------------------------------|-------------|
| SDH_RESP1 | SDHx_BA+0x834 | R   | SD Receiving Response Token Register 1 | 0x0000_0000 |

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

| Bits  | Description |                                                                                                                                                                                                                  |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | RESPTK1     | SD Receiving Response Token 1<br>The SD host controller will receive a response token for getting a reply from SD card when RIEN (SDH_CTL[1]) is set. This register contains the bit 15-8 of the response token. |

**SD Block Length Register (SDH\_BLEN)**

| Register | Offset        | R/W | Description              |  |  |  | Reset Value |
|----------|---------------|-----|--------------------------|--|--|--|-------------|
| SDH_BLEN | SDHx_BA+0x838 | R/W | SD Block Length Register |  |  |  | 0x0000_01FF |

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

| Bits   | Description |                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10:0] | BLKLEN      | <p><b>SD BLOCK LENGTH in Byte Unit</b></p> <p>An 11-bit value specifies the SD transfer byte count of a block. The actual byte count is equal to BLKLEN+1.</p> <p><b>Note:</b> The default SD block length is 512 bytes</p> |

**SD Response/Data-in Time-out Register (SDH\_TOUT)**

| Register | Offset        | R/W | Description                           | Reset Value |
|----------|---------------|-----|---------------------------------------|-------------|
| SDH_TOUT | SDHx_BA+0x83C | R/W | SD Response/Data-in Time-out Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23:0] | TOUT        | <p><b>SD Response/Data-in Time-out Value</b></p> <p>A 24-bit value specifies the time-out counts of response and data input. SD host controller will wait start bit of response or data-in until this value reached. The time period depends on SD engine clock frequency. Do not write a small number into this field, or you may never get response or data due to time-out.</p> <p><b>Note:</b> Filling 0x0 into this field will disable hardware time-out function.</p> |

## 6.29 External Bus Interface (EBI)

### 6.29.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.29.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)
- Supports address bus and data bus separate mode

### 6.29.3 Block Diagram



Figure 6.29-1 EBI Block Diagram

### 6.29.4 Basic Configuration

- Clock Source Configuration
  - Enable EBI controller clock in EBICKEN (CLK\_AHCLK[3]).
- Reset Configuration
  - Reset EBI controller in QSPI0RST (SYS\_IPRST0[3]).
- Pin Configuration

| Group | Pin Name | GPIO        | MFP  |
|-------|----------|-------------|------|
| EBI   | EBI_AD0  | PC.0, PG.9  | MFP2 |
|       | EBI_AD1  | PC.1, PG.10 | MFP2 |
|       | EBI_AD2  | PC.2, PG.11 | MFP2 |
|       | EBI_AD3  | PC.3, PG.12 | MFP2 |
|       | EBI_AD4  | PC.4, PG.13 | MFP2 |
|       | EBI_AD5  | PC.5, PG.14 | MFP2 |
|       | EBI_AD6  | PA.6, PD.8  | MFP2 |
|       | EBI_AD7  | PA.7, PD.9  | MFP2 |
|       | EBI_AD8  | PC.6, PE.14 | MFP2 |
|       | EBI_AD9  | PC.7, PE.15 | MFP2 |

|          |           |                    |      |
|----------|-----------|--------------------|------|
|          | EBI_AD10  | PD.3, PD.13, PE.1  | MFP2 |
|          | EBI_AD11  | PC.14, PD.2, PE.0  | MFP2 |
|          | EBI_AD12  | PB.15, PD.1, PH.8  | MFP2 |
|          | EBI_AD13  | PB.14, PD.0, PH.9  | MFP2 |
|          | EBI_AD14  | PB.13, PH.10       | MFP2 |
|          | EBI_AD15  | PB.12, PH.11       | MFP2 |
|          | EBI_ADR0  | PB.5, PH.7         | MFP2 |
|          | EBI_ADR1  | PB.4, PH.6         | MFP2 |
|          | EBI_ADR2  | PB.3, PH.5         | MFP2 |
|          | EBI_ADR3  | PB.2, PH.4         | MFP2 |
|          | EBI_ADR4  | PC.12, PH.3        | MFP2 |
|          | EBI_ADR5  | PC.11, PH.2        | MFP2 |
|          | EBI_ADR6  | PC.10, PH.1        | MFP2 |
|          | EBI_ADR7  | PC.9, PH.0         | MFP2 |
|          | EBI_ADR8  | PB.1, PG.0         | MFP2 |
|          | EBI_ADR9  | PB.0, PG.1         | MFP2 |
|          | EBI_ADR10 | PC.13, PE.8        | MFP2 |
|          | EBI_ADR11 | PE.9, PG.2         | MFP2 |
|          | EBI_ADR12 | PE.10, PG.3        | MFP2 |
|          | EBI_ADR13 | PE.11, PG.4        | MFP2 |
|          | EBI_ADR14 | PE.12, PF.11       | MFP2 |
|          | EBI_ADR15 | PE.13, PF.10       | MFP2 |
|          | EBI_ADR16 | PB.11, PC.8, PF.9  | MFP2 |
|          | EBI_ADR17 | PB.10, PF.8        | MFP2 |
|          | EBI_ADR18 | PB.9, PF.7         | MFP2 |
|          | EBI_ADR19 | PB.8, PF.6         | MFP2 |
|          | EBI_ALE   | PA.8, PE.2         | MFP2 |
|          | EBI_MCLK  | PA.9, PE.3         | MFP2 |
| EBI_nCS0 |           | PD.12, PD.14, PF.3 | MFP2 |
|          |           | PF.6               | MFP7 |
|          |           | PB.7               | MFP8 |
| EBI_nCS1 |           | PD.11, PF.2, PG.5  | MFP2 |
|          |           | PB.6               | MFP8 |
|          | EBI_nCS2  | PD.10, PG.6        | MFP2 |
|          | EBI_nRD   | PA.11, PE.5        | MFP2 |

|  |          |             |      |
|--|----------|-------------|------|
|  | EBI_nWR  | PA.10, PE.4 | MFP2 |
|  | EBI_nWRH | PB.6, PG.8  | MFP2 |
|  | EBI_nWRL | PB.7, PG.7  | MFP2 |

### 6.29.5 Functional Description

#### 6.29.5.1 EBI Area and Address Hit

The EBI mapping address is located at 0x6000\_0000 ~ 0x602F\_FFFF and the total memory space is 3MB. 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    | 0x6000_0000 ~ 0x600F_FFFF |
| EBI_nCS1    | 0x6010_0000 ~ 0x601F_FFFF |
| EBI_nCS2    | 0x6020_0000 ~ 0x602F_FFFF |

Table 6.29-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\_nCS0) to 0x6000\_0000 ~ 0x6003\_FFFF, 0x6004\_0000 ~ 0x6007\_FFFF, 0x6008\_0000 ~ 0x600B\_FFFF and 0x600C\_0000 ~ 0x600F\_FFFF simultaneously.

#### 6.29.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.29-2 shows the connection of 16-bit data width device and Figure 6.29-3 shows the connection of 8-bit data width device.



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



Figure 6.29-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.29.5.3 EBI Data Width Connection - Address Bus and Data Bus Separate Mode

The EBI supports address and data bus separate mode. User can enable this mode by setting ADSEOPEN (EBI\_CTLx[3]). When separate mode is enabled, EBI\_AD is dedicated for data bus and connected directly to device data bus, EBI\_ADR is dedicated for address bus.



Figure 6.29-4 Connection of 16-bit EBI Data Width with 16-bit Device in Separate mode



Figure 6.29-5 Connection of 8-bit EBI Data Width with 8-bit Device in Separate mode

### 6.29.5.4 EBI Operating Control

#### MCLK Control

In the chip, all EBI signals will be synchronized by EBI\_MCLK when EBI is operating. When chip connects to the external device with slower operating frequency, the EBI\_MCLK can divide most to HCLK/128 by setting MCLKDIV (EBI\_CTLx[10:8]). Therefore, chip can 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 ( $t_{ASU}$ ) 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~8 EBI\_MCLK cycles by setting TAHD (EBI\_TCTLx[10:8]), tACC can modulate to 1~32 EBI\_MCLK cycles by setting TACC (EBI\_TCTLx[7:3]), and tALE can modulate to 1~8 EBI\_MCLK cycles by setting TALE (EBI\_CTL0[18:16]). Some external device can support zero data access hold time accessing, the EBI controller can skip 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\_CTL0.

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

Table 6.29-2 Timing Control Parameter

Figure 6.29-6 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.29-6 Timing Control Waveform for 16-bit Data Width

Figure 6.29-7 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.29-7 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.29-8 shows the write operation of 8-bit width data in EBI\_AD[15:8] with EBI\_nWRH assertion.



Figure 6.29-8 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.29-9 shows idle cycles.



Figure 6.29-9 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\_CTL0[24]).

#### Address Data Separate Mode

When EBI is set as separate mode, the tALE, tLHD, tA2D cycles are ignored. EBI\_AD and EBI\_ADR are dedicated for data and address bus separately.



Figure 6.29-10 Timing Control Waveform for 16-bit Data Width for Separate Mode

#### 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.29-11.



Figure 6.29-11 Timing Control Waveform for Continuous Data Access Mode

### 6.29.6 Register Map

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

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

### 6.29.7 Register Description

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

| Register | Offset      | R/W | Description                                   |  |  |  | Reset Value |
|----------|-------------|-----|-----------------------------------------------|--|--|--|-------------|
| EBI_CTL0 | EBI_BA+0x00 | R/W | External Bus Interface Bank0 Control Register |  |  |  | 0x0000_0000 |
| EBI_CTL1 | EBI_BA+0x10 | R/W | External Bus Interface Bank1 Control Register |  |  |  | 0x0000_0000 |
| EBI_CTL2 | EBI_BA+0x20 | R/W | External Bus Interface Bank2 Control Register |  |  |  | 0x0000_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 | ADSEOPEN | CSPOLINV | DW16 | EN      |

| Bits    | Description |                                                                                                                                                                                                                                                                   |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                         |
| [24]    | WBUFEN      | <b>EBI Write Buffer Enable Bit</b><br>0 = EBI write buffer Disabled.<br>1 = EBI write buffer Enabled.<br><b>Note:</b> This bit only available in EBI_CTL0 register                                                                                                |
| [23:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                         |
| [18:16] | TALE        | <b>Extend Time of ALE</b><br>The EBI_ALE high pulse period (tALE) to latch the address can be controlled by TALE.<br>$tALE = (TALE + 1) * EBI\_MCLK$ .<br><b>Note:</b> This field only available in EBI_CTL0 register                                             |
| [15:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                         |
| [10:8]  | MCLKDIV     | <b>External Output Clock Divider</b><br>The frequency of EBI output clock (MCLK) is controlled by MCLKDIV as follow:<br>000 = HCLK/1.<br>001 = HCLK/2.<br>010 = HCLK/4.<br>011 = HCLK/8.<br>100 = HCLK/16.<br>101 = HCLK/32.<br>110 = HCLK/64.<br>111 = HCLK/128. |
| [7:5]   | Reserved    | Reserved.                                                                                                                                                                                                                                                         |

|     |                 |                                                                                                                                                                                                                                                     |
|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | <b>CACCESS</b>  | <b>Continuous Data Access Mode</b><br>When continuous access mode enabled, the tASU, tALE and tLHD cycles are bypass for continuous data transfer request.<br>0 = Continuous data access mode Disabled.<br>1 = Continuous data access mode Enabled. |
| [3] | <b>ADSEOPEN</b> | <b>EBI Address/Data Bus Separating Mode Enable Bit</b><br>0 = Address/Data Bus Separating Mode Disabled.<br>1 = Address/Data Bus Separating Mode Enabled.                                                                                           |
| [2] | <b>CSPOLINV</b> | <b>Chip Select Pin Polar Inverse</b><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.                                        |
| [1] | <b>DW16</b>     | <b>EBI Data Width 16-bit Select</b><br>This bit defines if the EBI data width is 8-bit or 16-bit.<br>0 = EBI data width is 8-bit.<br>1 = EBI data width is 16-bit.                                                                                  |
| [0] | <b>EN</b>       | <b>EBI Enable Bit</b><br>This bit is the functional enable bit for EBI.<br>0 = EBI function Disabled.<br>1 = EBI function Enabled.                                                                                                                  |

External Bus Interface Timing Control Register (EBI\_TCTLx)

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                           |
| [27:24] | R2R         | <b>Idle Cycle Between Read-to-read</b><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     | <b>Access Hold Time Disable Control When Write</b><br>0 = Data Access Hold Time (tAHD) during EBI writing Enabled.<br>1 = Data Access Hold Time (tAHD) during EBI writing Disabled.                                                                                 |
| [22]    | RAHDOFF     | <b>Access Hold Time Disable Control When Read</b><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         | <b>Idle Cycle After Write</b><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        | <b>EBI Data Access Hold Time</b><br>TAHD defines data access hold time (tAHD).<br>tAHD = (TAHD + 1) * EBI_MCLK.                                                                                                                                                     |
| [7:3]   | TACC        | <b>EBI Data Access Time</b><br>TACC defines data access time (tACC).                                                                                                                                                                                                |

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

## 6.30 USB 1.1 Device Controller (USBD)

### 6.30.1 Overview

There is one set of USB 2.0 full-speed device controller and transceiver in this device. It is compliant with USB 2.0 full-speed device specification and supports control/bulk/interrupt/ isochronous transfer types.

In this device controller, there are two main interfaces: the APB bus and USB bus which comes from the USB PHY transceiver. For the APB bus, the CPU can program control registers through it. There are 1KBytes internal SRAM as data buffer in this controller. For IN or OUT transfer, it is necessary to write data to SRAM or read data from SRAM through the APB interface or SIE. User needs to set the effective starting address of SRAM for each endpoint buffer through buffer segmentation register (USBD\_BUFSEGx).

There are 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 four different interrupt events in this controller. They are the no-event-wake-up, device plug-in or plug-out event, USB events, like IN ACK, OUT ACK etc, and BUS events, like suspend and resume, etc. Any event will cause an interrupt, and users just need to check the related event flags in interrupt event status register (USBD\_INTSTS) to acknowledge what kind of interrupt occurring, and then check the related USB Endpoint Status Register (USBD\_EPSTS0 and USBD\_EPSTS1) to acknowledge what kind of event occurring in this endpoint.

A software-disconnect function is also supported for this USB controller. It is used to simulate the disconnection of this device from the host. If user enables SE0 bit (USBD\_SE0), the USB controller will force the output of USB\_D+ and USB\_D- to level low and its function is disabled. After disable the SE0 bit, host will enumerate the USB device again.

For more information on the Universal Serial Bus, please refer to *Universal Serial Bus Specification Revision 1.1*.

### 6.30.2 Features

- Compliant with USB 2.0 Full-Speed specification
- Provides 1 interrupt vector with 4 different interrupt events (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 Kbyte buffer size
- Provides remote wake-up capability

### 6.30.3 Block Diagram



Figure 6.30-1 USB Block Diagram

### 6.30.4 Basic Configuration

The role of USB frame is determined by **USBROLE** (SYS\_USBPHY[1:0]). The internal USB 3.3V LDO can be enabled by **LDO33EN** (SYS\_USBPHY[8]). These two configurations are write-protection bits. Before writing to these bits, user must disable the register protection function. Refer to the description of **SYS\_REGLCTL** register for details. The USBD clock source is derived from PLL. User has to set the PLL related configurations before USB device controller is enabled. Set the **USBDCKEN** (CLK\_APBCLK0[27]) bit to enable USBD clock and 4-bit pre-scaler **USBDIV** (CLK\_CLKDIV0[7:4]) to generate the proper USBD clock rate.

#### 6.30.4.1 USB Device 1.1 Basic Configuration

- Clock source Configuration
  - Setting PLL controller (CLK\_PLLCTL).
  - Select the clock divider number of USBD peripheral clock on **USBDIV**(CLK\_CLKDIV0[7:4])
  - Enable USBD peripheral clock in **USBDCKEN** (CLK\_APBCLK0[27]).
- Reset Configuration
  - Reset USBD controller in **USBDRST** (SYS\_IPRST1[27]).
- Pin configuration

| Group | Pin Name   | GPIO  | MFP   |
|-------|------------|-------|-------|
| USB   | USB_D+     | PA.14 | MFP14 |
|       | USB_D-     | PA.13 | MFP14 |
|       | USB_OTG_ID | PA.15 | MFP14 |
|       | USB_VBUS   | PA.12 | MFP14 |

### 6.30.5 Functional Description

#### 6.30.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.30.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.30.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.30.5.4 VBUS Detection De-bouncing

A USB device may be plugged-in or unplugged 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.30.5.5 Interrupt control

This USB provides 1 interrupt vector with 4 interrupt events (NEVWK, VBUSDET, USB and BUS). 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 the other USB interrupt events happened more than 20ms after the chip is waked up from Power-down mode. After the chip enters Power-down mode, any change on USB\_VBUS, USB\_D+ and USB\_D- can wake up this chip if USB wake-up function is enabled. If this change is not intentionally, no interrupt but NEVWK interrupt will occur. After waking up by USB, this interrupt will occur when no the other USB interrupt events are presented for more than 20ms. Figure 6.30-2 shows the control flow of wake-up interrupt.



Figure 6.30-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\_EPSTS0 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, time-out, and resume. A user can read USBD\_ATTR to acknowledge bus events.

#### 6.30.5.6 Power Saving

User can write 0 to USBD\_ATTR[4] to disable PHY under special circumstances, like suspend, to conserve power.

#### 6.30.5.7 Buffer Control

There is 1 Kbyte of 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.30-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 0x08h and USBD\_MXPLD0 is set as 0x40h, 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.



Figure 6.30-3 Endpoint SRAM Structure

### 6.30.5.8 Handling Transactions with USB Device Peripheral

User can use interrupt or polling 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 polling USBD\_INTSTS to get these events without interrupt. The following is the control flow with interrupt enabled.

When USB host has requested data from a device controller, user needs to prepare related data in the specified endpoint buffer in advance. After buffering the required data, user needs to write the actual data length in the specified USBD\_MXPLDx register. Once this register is written, the internal signal “In\_Rdy” will be asserted and the buffering data will be transmitted immediately after receiving associated IN token from Host. Note that after transferring the specified data, the signal “In\_Rdy” will de-assert automatically by hardware.



Figure 6.30-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.30-5 Data Out Transfer

### 6.30.5.9 Link Power Management(LPM)

Power Management(LPM) which is similar to the suspend/resume function, but has transitional

latencies of tens of microseconds between power states (instead of three to greater than 20 millisecond latencies of the USB2.0 suspend/resume)

New fast mechanism for transitioning the bus on a root port from an enable state (called L0), to a new sleep state(called L1), detail define for L0 and L1 state see Table 6.30-1, the register USBD\_ATTR & USBD\_LPMATTR can let user know current power state for LPM mechanism.

| LPM State   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L0(On)      | In this state, the port is enabled for propagation of transaction signaling traffic. A port in L0 is either actively transmitting or receiving data (L0-Active) or able to do so but not currently transmitting or receiving information (L0-Idle). While in this state Start-of-Frame (SOF) packets are issued by the host at a rate corresponding to the speed of the client device                                                                                                                                                                                                                                                                                                                                                                                                 |
| L1(Sleep)   | L1 is similar to L2 (below) but supports finer granularity in use. When in L1, the line state is identical to L2. Entry to L1 is started by a request to a hub or host port to transition to L1. A LPM transaction is sent to the downstream device. The requested transition can only occur if the device response with an ACK handshake. Exit from L1 is via remote wake, resume signaling, reset signaling or disconnect. L1 does not impose any specific power draw requirements (from VBUS) on the attached device as L2 does. Either the host or device can initiate resume signaling when in L1. Although the signaling levels of resume are the same as L2, the 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 or host port to transition to suspend. The device discovers the suspend condition via observing 3ms of inactivity. The resultant line state is either Low or Full-speed idle. L2 also imposes power draw requirements (from VBUS) on the attached device. Exit from this state is via remote wake, resume signaling, reset signaling or disconnect.                                                                                                                                                                                                                                                                                                                         |
| L3(Off)     | In this state, the port is not capable of performing any data signaling. It corresponds to the powered-off, disconnected, and disabled states                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Table 6.30-1 USB Link Power Manager (Lx) States

The state transaction process please refer to Figure 6.30-6, and for more information on the USB Link Power Manager(LPM), please refer to USB2.0 Link Power Mangement ECN.



Figure 6.30-6 LPM State Transition Diagram

### 6.30.6 Register Map

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

| Register                     | Offset        | R/W | Description                                                  | Reset Value |
|------------------------------|---------------|-----|--------------------------------------------------------------|-------------|
| <b>USBD Base Address:</b>    |               |     |                                                              |             |
| <b>USBD_BA = 0x400C_0000</b> |               |     |                                                              |             |
| <b>USBD_INTEN</b>            | USBD_BA+0x000 | R/W | USB Device Interrupt Enable Register                         | 0x0000_0000 |
| <b>USBD_INTSTS</b>           | USBD_BA+0x004 | R/W | USB Device Interrupt Event Status Register                   | 0x0000_0000 |
| <b>USBD_FADDR</b>            | USBD_BA+0x008 | R/W | USB Device Function Address Register                         | 0x0000_0000 |
| <b>USBD_EPSTS</b>            | USBD_BA+0x00C | R   | USB Device Endpoint Status Register                          | 0x0000_0000 |
| <b>USBD_ATTR</b>             | USBD_BA+0x010 | R/W | USB Device Bus Status and Attribution Register               | 0x0000_0040 |
| <b>USBD_VBUSDET</b>          | USBD_BA+0x014 | R   | USB Device VBUS Detection Register                           | 0x0000_0000 |
| <b>USBD_STBUFSEG</b>         | USBD_BA+0x018 | R/W | SETUP Token Buffer Segmentation Register                     | 0x0000_0000 |
| <b>USBD_EPSTS0</b>           | USBD_BA+0x020 | R   | USB Device Endpoint Status Register 0                        | 0x0000_0000 |
| <b>USBD_EPSTS1</b>           | USBD_BA+0x024 | R   | USB Device Endpoint Status Register 1                        | 0x0000_0000 |
| <b>USBD_LPMATTR</b>          | USBD_BA+0x088 | R   | USB LPM Attribution Register                                 | 0x0000_0000 |
| <b>USBD_FN</b>               | USBD_BA+0x08C | R   | USB Frame number Register                                    | 0x0000_0XXX |
| <b>USBD_SE0</b>              | USBD_BA+0x090 | R/W | USB Device Drive SE0 Control Register                        | 0x0000_0001 |
| <b>USBD_BUFSEG0</b>          | USBD_BA+0x500 | R/W | Endpoint 0 Buffer Segmentation Register                      | 0x0000_0000 |
| <b>USBD_MXPLD0</b>           | USBD_BA+0x504 | R/W | Endpoint 0 Maximal Payload Register                          | 0x0000_0000 |
| <b>USBD_CFG0</b>             | USBD_BA+0x508 | R/W | Endpoint 0 Configuration Register                            | 0x0000_0000 |
| <b>USBD_CFGP0</b>            | USBD_BA+0x50C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| <b>USBD_BUFSEG1</b>          | USBD_BA+0x510 | R/W | Endpoint 1 Buffer Segmentation Register                      | 0x0000_0000 |
| <b>USBD_MXPLD1</b>           | USBD_BA+0x514 | R/W | Endpoint 1 Maximal Payload Register                          | 0x0000_0000 |
| <b>USBD_CFG1</b>             | USBD_BA+0x518 | R/W | Endpoint 1 Configuration Register                            | 0x0000_0000 |
| <b>USBD_CFGP1</b>            | USBD_BA+0x51C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| <b>USBD_BUFSEG2</b>          | USBD_BA+0x520 | R/W | Endpoint 2 Buffer Segmentation Register                      | 0x0000_0000 |
| <b>USBD_MXPLD2</b>           | USBD_BA+0x524 | R/W | Endpoint 2 Maximal Payload Register                          | 0x0000_0000 |
| <b>USBD_CFG2</b>             | USBD_BA+0x528 | R/W | Endpoint 2 Configuration Register                            | 0x0000_0000 |
| <b>USBD_CFGP2</b>            | USBD_BA+0x52C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| <b>USBD_BUFSEG3</b>          | USBD_BA+0x530 | R/W | Endpoint 3 Buffer Segmentation Register                      | 0x0000_0000 |
| <b>USBD_MXPLD3</b>           | USBD_BA+0x534 | R/W | Endpoint 3 Maximal Payload Register                          | 0x0000_0000 |
| <b>USBD_CFG3</b>             | USBD_BA+0x538 | R/W | Endpoint 3 Configuration Register                            | 0x0000_0000 |

|                      |               |     |                                                               |             |
|----------------------|---------------|-----|---------------------------------------------------------------|-------------|
| <b>USBD_CFGP3</b>    | USBD_BA+0x53C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_BUFSEG4</b>  | USBD_BA+0x540 | R/W | Endpoint 4 Buffer Segmentation Register                       | 0x0000_0000 |
| <b>USBD_MXPLD4</b>   | USBD_BA+0x544 | R/W | Endpoint 4 Maximal Payload Register                           | 0x0000_0000 |
| <b>USBD_CFG4</b>     | USBD_BA+0x548 | R/W | Endpoint 4 Configuration Register                             | 0x0000_0000 |
| <b>USBD_CFGP4</b>    | USBD_BA+0x54C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_BUFSEG5</b>  | USBD_BA+0x550 | R/W | Endpoint 5 Buffer Segmentation Register                       | 0x0000_0000 |
| <b>USBD_MXPLD5</b>   | USBD_BA+0x554 | R/W | Endpoint 5 Maximal Payload Register                           | 0x0000_0000 |
| <b>USBD_CFG5</b>     | USBD_BA+0x558 | R/W | Endpoint 5 Configuration Register                             | 0x0000_0000 |
| <b>USBD_CFGP5</b>    | USBD_BA+0x55C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_BUFSEG6</b>  | USBD_BA+0x560 | R/W | Endpoint 6 Buffer Segmentation Register                       | 0x0000_0000 |
| <b>USBD_MXPLD6</b>   | USBD_BA+0x564 | R/W | Endpoint 6 Maximal Payload Register                           | 0x0000_0000 |
| <b>USBD_CFG6</b>     | USBD_BA+0x568 | R/W | Endpoint 6 Configuration Register                             | 0x0000_0000 |
| <b>USBD_CFGP6</b>    | USBD_BA+0x56C | R/W | Endpoint 6 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_BUFSEG7</b>  | USBD_BA+0x570 | R/W | Endpoint 7 Buffer Segmentation Register                       | 0x0000_0000 |
| <b>USBD_MXPLD7</b>   | USBD_BA+0x574 | R/W | Endpoint 7 Maximal Payload Register                           | 0x0000_0000 |
| <b>USBD_CFG7</b>     | USBD_BA+0x578 | R/W | Endpoint 7 Configuration Register                             | 0x0000_0000 |
| <b>USBD_CFGP7</b>    | USBD_BA+0x57C | R/W | Endpoint 7 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_BUFSEG8</b>  | USBD_BA+0x580 | R/W | Endpoint 8 Buffer Segmentation Register                       | 0x0000_0000 |
| <b>USBD_MXPLD8</b>   | USBD_BA+0x584 | R/W | Endpoint 8 Maximal Payload Register                           | 0x0000_0000 |
| <b>USBD_CFG8</b>     | USBD_BA+0x588 | R/W | Endpoint 8 Configuration Register                             | 0x0000_0000 |
| <b>USBD_CFGP8</b>    | USBD_BA+0x58C | R/W | Endpoint 8 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_BUFSEG9</b>  | USBD_BA+0x590 | R/W | Endpoint 9 Buffer Segmentation Register                       | 0x0000_0000 |
| <b>USBD_MXPLD9</b>   | USBD_BA+0x594 | R/W | Endpoint 9 Maximal Payload Register                           | 0x0000_0000 |
| <b>USBD_CFG9</b>     | USBD_BA+0x598 | R/W | Endpoint 9 Configuration Register                             | 0x0000_0000 |
| <b>USBD_CFGP9</b>    | USBD_BA+0x59C | R/W | Endpoint 9 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_BUFSEG10</b> | USBD_BA+0x5A0 | R/W | Endpoint 10 Buffer Segmentation Register                      | 0x0000_0000 |
| <b>USBD_MXPLD10</b>  | USBD_BA+0x5A4 | R/W | Endpoint 10 Maximal Payload Register                          | 0x0000_0000 |
| <b>USBD_CFG10</b>    | USBD_BA+0x5A8 | R/W | Endpoint 10 Configuration Register                            | 0x0000_0000 |
| <b>USBD_CFGP10</b>   | USBD_BA+0x5AC | R/W | Endpoint 10 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| <b>USBD_BUFSEG11</b> | USBD_BA+0x5B0 | R/W | Endpoint 11 Buffer Segmentation Register                      | 0x0000_0000 |

|                     |               |     |                                                               |             |
|---------------------|---------------|-----|---------------------------------------------------------------|-------------|
| <b>USBD_MXPLD11</b> | USBD_BA+0x5B4 | R/W | Endpoint 11 Maximal Payload Register                          | 0x0000_0000 |
| <b>USBD_CFG11</b>   | USBD_BA+0x5B8 | R/W | Endpoint 11 Configuration Register                            | 0x0000_0000 |
| <b>USBD_CFGP11</b>  | USBD_BA+0x5BC | R/W | Endpoint 11 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |

| Memory Type                  | Address                             | Size       | Description                                                                                                                         |
|------------------------------|-------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <b>USBD_BA = 0x400C_0000</b> |                                     |            |                                                                                                                                     |
| <b>USBD_SRAM</b>             | USBD_BA+0x100<br>~<br>USBD_BA+0x4FF | 1024 Bytes | The SRAM is used for the entire endpoints buffer.<br>Refer to section 6.30.5.7 for the endpoint SRAM structure and its description. |

### 6.30.7 Register Description

#### USB Interrupt Enable Register (USBD\_INTEN)

| Register   | Offset        | R/W | Description                          |  |  |  |  | Reset Value |
|------------|---------------|-----|--------------------------------------|--|--|--|--|-------------|
| USBD_INTEN | USBD_BA+0x000 | R/W | USB Device Interrupt Enable Register |  |  |  |  | 0x0000_0000 |

|          |          |    |        |          |          |        |        |
|----------|----------|----|--------|----------|----------|--------|--------|
| 31       | 30       | 29 | 28     | 27       | 26       | 25     | 24     |
| 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 |          |    | SOFIEN | NEVWKIEN | VBDETIEN | USBIEN | BUSIEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [15]    | INNAKEN     | <b>Active NAK Function and Its Status in IN Token</b><br>0 = When 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        | <b>Wake-up Function Enable Bit</b><br>0 = USB wake-up function Disabled.<br>1 = USB wake-up function Enabled.                                                                                                                                                                                                                                                                                                                      |
| [7:5]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [4]     | SOFIEN      | <b>Start of Frame Interrupt Enable Bit</b><br>0 = SOF Interrupt Disabled.<br>1 = SOF Interrupt Enabled.                                                                                                                                                                                                                                                                                                                            |
| [3]     | NEVWKIEN    | <b>USB No-event-wake-up Interrupt Enable Bit</b><br>0 = No-event-wake-up Interrupt Disabled.<br>1 = No-event-wake-up Interrupt Enabled.                                                                                                                                                                                                                                                                                            |
| [2]     | VBDETIEN    | <b>VBUS Detection Interrupt Enable Bit</b><br>0 = VBUS detection Interrupt Disabled.<br>1 = VBUS detection Interrupt Enabled.                                                                                                                                                                                                                                                                                                      |
| [1]     | USBIEN      | <b>USB Event Interrupt Enable Bit</b><br>0 = USB event interrupt Disabled.<br>1 = USB event interrupt Enabled.                                                                                                                                                                                                                                                                                                                     |

|     |               |                                                                                                                |
|-----|---------------|----------------------------------------------------------------------------------------------------------------|
| [0] | <b>BUSIEN</b> | <b>Bus Event Interrupt Enable Bit</b><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 |  |  |  | 0x0000_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 | EPEVT0 |
| 15       | 14       | 13     | 12     | 11      | 10      | 9      | 8      |
| Reserved |          |        |        |         |         |        |        |
| 7        | 6        | 5      | 4      | 3       | 2       | 1      | 0      |
| Reserved |          |        | SOFIF  | NEVWKIF | VBDETIF | USBIF  | BUSIF  |

| Bits    | Description |                                                                                                                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | SETUP       | <b>Setup Event Status</b><br>0 = No Setup event.<br>1 = Setup event occurred, cleared by write 1 to USBD_INTSTS[31].                                                                                                                                     |
| [30:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                |
| [27]    | EPEVT11     | <b>Endpoint 11's USB Event Status</b><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 was occurred, cleared by write 1 to USBD_INTSTS[27] or USBD_INTSTS[1]. |
| [26]    | EPEVT10     | <b>Endpoint 10's USB Event Status</b><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 was occurred, cleared by write 1 to USBD_INTSTS[26] or USBD_INTSTS[1].  |
| [25]    | EPEVT9      | <b>Endpoint 9's USB Event Status</b><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 was occurred, cleared by write 1 to USBD_INTSTS[25] or USBD_INTSTS[1].      |
| [24]    | EPEVT8      | <b>Endpoint 8's USB Event Status</b><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 was occurred, cleared by write 1 to USBD_INTSTS[24] or USBD_INTSTS[1].      |
| [23]    | EPEVT7      | <b>Endpoint 7's USB Event Status</b><br>0 = No event occurred in endpoint 7.<br>1 = USB event occurred on Endpoint 7, check USBD_EPSTS0[31:28] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[23] or USBD_INTSTS[1].    |

|        |                 |                                                                                                                                                                                                                                                        |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [22]   | <b>EPEVT6</b>   | <b>Endpoint 6's USB Event Status</b><br>0 = No event occurred in endpoint 6.<br>1 = USB event occurred on Endpoint 6, check USBD_EPSTS0[27:24] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[22] or USBD_INTSTS[1].  |
| [21]   | <b>EPEVT5</b>   | <b>Endpoint 5's USB Event Status</b><br>0 = No event occurred in endpoint 5.<br>1 = USB event occurred on Endpoint 5, check USBD_EPSTS0[23:20] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[21] or USBD_INTSTS[1].  |
| [20]   | <b>EPEVT4</b>   | <b>Endpoint 4's USB Event Status</b><br>0 = No event occurred in endpoint 4.<br>1 = USB event occurred on Endpoint 4, check USBD_EPSTS0[19:16] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[20] or USBD_INTSTS[1].  |
| [19]   | <b>EPEVT3</b>   | <b>Endpoint 3's USB Event Status</b><br>0 = No event occurred in endpoint 3.<br>1 = USB event occurred on Endpoint 3, check USBD_EPSTS0[15:12] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[19] or USBD_INTSTS[1].  |
| [18]   | <b>EPEVT2</b>   | <b>Endpoint 2's USB Event Status</b><br>0 = No event occurred in endpoint 2.<br>1 = USB event occurred on Endpoint 2, check USBD_EPSTS0[11:8] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[18] or USBD_INTSTS[1].   |
| [17]   | <b>EPEVT1</b>   | <b>Endpoint 1's USB Event Status</b><br>0 = No event occurred in endpoint 1.<br>1 = USB event occurred on Endpoint 1, check USBD_EPSTS0[7:4] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[17] or USBD_INTSTS[1].    |
| [16]   | <b>EPEVT0</b>   | <b>Endpoint 0's USB Event Status</b><br>0 = No event occurred in endpoint 0.<br>1 = USB event occurred on Endpoint 0, check USBD_EPSTS0[3:0] to know which kind of USB event was occurred, cleared by write 1 to USBD_INTSTS[16] or USBD_INTSTS[1].    |
| [15:5] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                              |
| [4]    | <b>SOFIF</b>    | <b>Start of Frame Interrupt Status</b><br>0 = SOF event does not occur.<br>1 = SOF event occurred, cleared by write 1 to USBD_INTSTS[4].                                                                                                               |
| [3]    | <b>NEVWKIF</b>  | <b>No-event-wake-up Interrupt Status</b><br>0 = NEVWK event does not occur.<br>1 = No-event-wake-up event occurred, cleared by write 1 to USBD_INTSTS[3].                                                                                              |
| [2]    | <b>VBDETIF</b>  | <b>VBUS Detection Interrupt Status</b><br>0 = There is not attached/detached event in the USB.<br>1 = There is attached/detached event in the USB bus and it is cleared by write 1 to USBD_INTSTS[2].                                                  |
| [1]    | <b>USBIF</b>    | <b>USB Event Interrupt Status</b><br>The USB event includes the SETUP Token, IN Token, OUT ACK, ISO IN, or ISO OUT events in the bus.<br>0 = No USB event occurred.<br>1 = USB event occurred, check EPSTS0~5[2:0] to know which kind of USB event was |

|     |              |                                                                                                                                                                                                                                                                                           |
|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |              | occurred, cleared by write 1 to USBD_INTSTS[1] or EPSTS0~11 and SETUP (USBD_INTSTS[31]).                                                                                                                                                                                                  |
| [0] | <b>BUSIF</b> | <b>BUS Interrupt Status</b><br>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 was occurred, cleared by write 1 to USBD_INTSTS[0]. |

**USB Device Function Address Register (USBD\_FADDR)**

A 7-bit value is used as the address of a device on the USB BUS.

| Register   | Offset        | R/W | Description                          |  |  |  |  | Reset Value |
|------------|---------------|-----|--------------------------------------|--|--|--|--|-------------|
| USBD_FADDR | USBD_BA+0x008 | R/W | USB Device Function Address Register |  |  |  |  | 0x0000_0000 |



| 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+0x00C | R   | USB Device Endpoint 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  |
| OV Reserved |    |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                  |
| [7]    | OV          | <b>Overrun</b><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  | Reserved | DPPUEN |
| 7        | 6        | 5        | 4         | 3      | 2      | 1        | 0      |
| USBEN    | Reserved | RWAKEUP  | PHYEN     | TOUT   | RESUME | SUSPEND  | USBRST |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                            |
| [13]    | L1RESUME    | <b>LPM L1 Resume (Read Only)</b><br>0 = Bus no LPM L1 state resume.<br>1 = LPM L1 state Resume from LPM L1 state suspend.                                                                                                                                                                                                                                            |
| [12]    | L1SUSPEND   | <b>LPM L1 Suspend (Read Only)</b><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      | <b>LPM Token Acknowledge Enable Bit</b><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       | <b>CPU Access USB SRAM Size Mode Selection</b><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]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                            |
| [8]     | DPPUEN      | <b>Pull-up Resistor on USB_DP Enable Bit</b><br>0 = Pull-up resistor in USB_D+ bus Disabled.<br>1 = Pull-up resistor in USB_D+ bus Active.                                                                                                                                                                                                                           |
| [7]     | USBEN       | <b>USB Controller Enable Bit</b><br>0 = USB Controller Disabled.<br>1 = USB Controller Enabled.                                                                                                                                                                                                                                                                      |
| [6]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                            |
| [5]     | RWAKEUP     | <b>Remote Wake-up</b>                                                                                                                                                                                                                                                                                                                                                |

|     |                |                                                                                                                                          |
|-----|----------------|------------------------------------------------------------------------------------------------------------------------------------------|
|     |                | 0 = Release the USB bus from K state.<br>1 = Force USB bus to K (USB_D+ low, USB_D-: high) state, used for remote wake-up.               |
| [4] | <b>PHYEN</b>   | <b>PHY Transceiver Function Enable Bit</b><br>0 = PHY transceiver function Disabled.<br>1 = PHY transceiver function Enabled.            |
| [3] | <b>TOUT</b>    | <b>Time-out Status (Read Only)</b><br>0 = No time-out.<br>1 = No Bus response more than 18 bits time.                                    |
| [2] | <b>RESUME</b>  | <b>Resume Status (Read Only)</b><br>0 = No bus resume.<br>1 = Resume from suspend.                                                       |
| [1] | <b>SUSPEND</b> | <b>Suspend Status (Read Only)</b><br>0 = Bus no suspend.<br>1 = Bus idle more than 3ms, either cable is plugged off or host is sleeping. |
| [0] | <b>USBRST</b>  | <b>USB Reset Status (Read Only)</b><br>0 = Bus no reset.<br>1 = Bus reset when SE0 (single-ended 0) more than 2.5us.                     |

USB Device VBUS Detection Register (USBD\_VBUSDET)

| Register     | Offset        | R/W | Description                        | Reset Value |
|--------------|---------------|-----|------------------------------------|-------------|
| USBD_VBUSDET | USBD_BA+0x014 | R   | USB Device VBUS Detection Register | 0x0000_0000 |

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

| Bits   | Description    |                                                                                                                                |
|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved       | Reserved.                                                                                                                      |
| [0]    | <b>VBUSDET</b> | <b>Device VBUS Detection</b><br>0 = Controller is not attached to the USB host.<br>1 = Controller is attached to the USB host. |

USB SETUP Token Buffer Segmentation Register (USBD\_STBUFSEG)

| Register      | Offset        | R/W | Description                              |  |  |  |  | Reset Value |
|---------------|---------------|-----|------------------------------------------|--|--|--|--|-------------|
| USBD_STBUFSEG | USBD_BA+0x018 | R/W | SETUP Token Buffer Segmentation Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                        |
| [8:3]  | STBUFSEG    | <p><b>SETUP Token Buffer Segmentation</b></p> <p>It is used to indicate the offset address for the SETUP token with the USB Device SRAM starting address. The effective starting address is USBD_SRAM address + {STBUFSEG, 3'b000}</p> <p>Where the USBD_SRAM address = USBD_BA+0x100h.</p> <p><b>Note:</b> It is used for SETUP token only.</p> |
| [2:0]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                        |

**USB Endpoint Status Register 0 (USBD\_EPSTS0)**

| Register           | Offset        | R/W | Description                           |  |  |  | Reset Value |
|--------------------|---------------|-----|---------------------------------------|--|--|--|-------------|
| <b>USBD_EPSTS0</b> | USBD_BA+0x020 | R   | USB Device Endpoint Status Register 0 |  |  |  | 0x0000_0000 |

|               |    |    |    |               |    |    |    |
|---------------|----|----|----|---------------|----|----|----|
| 31            | 30 | 29 | 28 | 27            | 26 | 25 | 24 |
| <b>EPSTS7</b> |    |    |    | <b>EPSTS6</b> |    |    |    |
| 23            | 22 | 21 | 20 | 19            | 18 | 17 | 16 |
| <b>EPSTS5</b> |    |    |    | <b>EPSTS4</b> |    |    |    |
| 15            | 14 | 13 | 12 | 11            | 10 | 9  | 8  |
| <b>EPSTS3</b> |    |    |    | <b>EPSTS2</b> |    |    |    |
| 7             | 6  | 5  | 4  | 3             | 2  | 1  | 0  |
| <b>EPSTS1</b> |    |    |    | <b>EPSTS0</b> |    |    |    |

| Bits    | Description                                                                                                                                                                                                                                                                   |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | <b>EPSTS7</b><br><b>Endpoint 7 Status</b><br>These bits are used to indicate the current status of this endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0011 = Setup ACK.<br>0110 = Out Packet Data1 ACK.<br>0111 = Isochronous transfer end. |
| [27:24] | <b>EPSTS6</b><br><b>Endpoint 6 Status</b><br>These bits are used to indicate the current status of this endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0011 = Setup ACK.<br>0110 = Out Packet Data1 ACK.<br>0111 = Isochronous transfer end. |
| [23:20] | <b>EPSTS5</b><br><b>Endpoint 5 Status</b><br>These bits are used to indicate the current status of this endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0011 = Setup ACK.<br>0110 = Out Packet Data1 ACK.<br>0111 = Isochronous transfer end. |

|         |        |                                                                                                                                                                                                                                                              |
|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19:16] | EPSTS4 | <b>Endpoint 4 Status</b><br>These Bits Are Used To Indicate The Current Status Of This Endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0110 = Out Packet Data1 ACK.<br>0011 = Setup ACK.<br>0111 = Isochronous Transfer End. |
| [15:12] | EPSTS3 | <b>Endpoint 3 Status</b><br>These bits are used to indicate the current status of this endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0110 = Out Packet Data1 ACK.<br>0011 = Setup ACK.<br>0111 = Isochronous transfer end. |
| [11:8]  | EPSTS2 | <b>Endpoint 2 Status</b><br>These bits are used to indicate the current status of this endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0110 = Out Packet Data1 ACK.<br>0011 = Setup ACK.<br>0111 = Isochronous transfer end. |
| [7:4]   | EPSTS1 | <b>Endpoint 1 Status</b><br>These bits are used to indicate the current status of this endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0110 = Out Packet Data1 ACK.<br>0011 = Setup ACK.<br>0111 = Isochronous transfer end. |
| [3:0]   | EPSTS0 | <b>Endpoint 0 Status</b><br>These bits are used to indicate the current status of this endpoint<br>0000 = In ACK.<br>0001 = In NAK.<br>0010 = Out Packet Data0 ACK.<br>0110 = Out Packet Data1 ACK.<br>0011 = Setup ACK.<br>0111 = Isochronous transfer end. |

**USB Endpoint Status Register 1 (USBD\_EPSTS1)**

| Register           | Offset        | R/W | Description                           |  |  |  | Reset Value |
|--------------------|---------------|-----|---------------------------------------|--|--|--|-------------|
| <b>USBD_EPSTS1</b> | USBD_BA+0x024 | R   | USB Device Endpoint Status Register 1 |  |  |  | 0x0000_0000 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                   |
|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                         |
| [15:12] | <b>EPSTS11</b>  | <p><b>Endpoint 11 Status</b></p> <p>These bits are used to indicate the current status of this endpoint</p> <p>0000 = In ACK.<br/>0001 = In NAK.<br/>0010 = Out Packet Data0 ACK.<br/>0011 = Setup ACK.<br/>0110 = Out Packet Data1 ACK.<br/>0111 = Isochronous transfer end.</p> |
| [11:8]  | <b>EPSTS10</b>  | <p><b>Endpoint 10 Status</b></p> <p>These bits are used to indicate the current status of this endpoint</p> <p>0000 = In ACK.<br/>0001 = In NAK.<br/>0010 = Out Packet Data0 ACK.<br/>0011 = Setup ACK.<br/>0110 = Out Packet Data1 ACK.<br/>0111 = Isochronous transfer end.</p> |
| [7:4]   | <b>EPSTS9</b>   | <p><b>Endpoint 9 Status</b></p> <p>These bits are used to indicate the current status of this endpoint</p> <p>0000 = In ACK.<br/>0001 = In NAK.<br/>0010 = Out Packet Data0 ACK.<br/>0011 = Setup ACK.<br/>0110 = Out Packet Data1 ACK.<br/>0111 = Isochronous transfer end.</p>  |
| [3:0]   | <b>EPSTS8</b>   | <p><b>Endpoint 8 Status</b></p> <p>These bits are used to indicate the current status of this endpoint</p>                                                                                                                                                                        |

|  |  |                                                                                                                                                                                      |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | <p>0000 = In ACK.</p> <p>0001 = In NAK.</p> <p>0010 = Out Packet Data0 ACK.</p> <p>0011 = Setup ACK.</p> <p>0110 = Out Packet Data1 ACK.</p> <p>0111 = Isochronous transfer end.</p> |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

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

| Bits   | Description |                                                                                                              |
|--------|-------------|--------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                    |
| [8]    | LPMRWAKUP   | <b>LPM Remote Wakeup</b><br>This bit contains the bRemoteWake value received with last ACK LPM Token         |
| [7:4]  | LPMBESL     | <b>LPM Best Effort Service Latency</b><br>These bits contain the BESL value received with last ACK LPM Token |
| [3:0]  | LPMLINKSTS  | <b>LPM Link State</b><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+0x08C | R   | USB Frame number Register | 0x0000_0XXX |

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

| Bits    | Description |                                                                                                     |
|---------|-------------|-----------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                           |
| [10:0]  | FN          | <b>Frame Number</b><br>These bits contain the 11-bits frame number in the last received SOF packet. |

USB Drive SE0 Register (USBD\_SE0)

| Register | Offset        | R/W | Description                           | Reset Value |
|----------|---------------|-----|---------------------------------------|-------------|
| USBD_SE0 | USBD_BA+0x090 | R/W | USB Device Drive SE0 Control Register | 0x0000_0001 |

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

| Bits   | Description |                                                                                                                                                                                                                               |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                     |
| [0]    | SE0         | <p><b>Drive Single Ended Zero in USB Bus</b></p> <p>The Single Ended Zero (SE0) is when both lines (USB_D+ and USB_D-) are being pulled low.</p> <p>0 = Normal operation.<br/>1 = Force USB PHY transceiver to drive SE0.</p> |

USB Buffer Segmentation Register (USB BUFSEGx)

| Register             | Offset        | R/W | Description                              | Reset Value |
|----------------------|---------------|-----|------------------------------------------|-------------|
| <b>USBD_BUFSEG0</b>  | USBD_BA+0x500 | R/W | Endpoint 0 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG1</b>  | USBD_BA+0x510 | R/W | Endpoint 1 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG2</b>  | USBD_BA+0x520 | R/W | Endpoint 2 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG3</b>  | USBD_BA+0x530 | R/W | Endpoint 3 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG4</b>  | USBD_BA+0x540 | R/W | Endpoint 4 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG5</b>  | USBD_BA+0x550 | R/W | Endpoint 5 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG6</b>  | USBD_BA+0x560 | R/W | Endpoint 6 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG7</b>  | USBD_BA+0x570 | R/W | Endpoint 7 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG8</b>  | USBD_BA+0x580 | R/W | Endpoint 8 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG9</b>  | USBD_BA+0x590 | R/W | Endpoint 9 Buffer Segmentation Register  | 0x0000_0000 |
| <b>USBD_BUFSEG10</b> | USBD_BA+0x5A0 | R/W | Endpoint 10 Buffer Segmentation Register | 0x0000_0000 |
| <b>USBD_BUFSEG11</b> | USBD_BA+0x5B0 | R/W | Endpoint 11 Buffer Segmentation Register | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |
| [8:3]  | <b>BUFSEG</b>   | <p><b>Endpoint Buffer Segmentation</b></p> <p>It is used to indicate the offset address for each endpoint with the USB SRAM starting address. The effective starting address of the endpoint is USBD_SRAM address + { BUFSEG, 3'b000}</p> <p>Where the USBD_SRAM address = USBD_BA+0x100h.</p> <p>Refer to the section 6.30.5.7 for the endpoint SRAM structure and its description.</p> |
| [2:0]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |

USB Maximal Payload Register (USB\_MXPLDx)

| Register            | Offset        | R/W | Description                          | Reset Value |
|---------------------|---------------|-----|--------------------------------------|-------------|
| <b>USBD_MXPLD0</b>  | USBD_BA+0x504 | R/W | Endpoint 0 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD1</b>  | USBD_BA+0x514 | R/W | Endpoint 1 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD2</b>  | USBD_BA+0x524 | R/W | Endpoint 2 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD3</b>  | USBD_BA+0x534 | R/W | Endpoint 3 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD4</b>  | USBD_BA+0x544 | R/W | Endpoint 4 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD5</b>  | USBD_BA+0x554 | R/W | Endpoint 5 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD6</b>  | USBD_BA+0x564 | R/W | Endpoint 6 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD7</b>  | USBD_BA+0x574 | R/W | Endpoint 7 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD8</b>  | USBD_BA+0x584 | R/W | Endpoint 8 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD9</b>  | USBD_BA+0x594 | R/W | Endpoint 9 Maximal Payload Register  | 0x0000_0000 |
| <b>USBD_MXPLD10</b> | USBD_BA+0x5A4 | R/W | Endpoint 10 Maximal Payload Register | 0x0000_0000 |
| <b>USBD_MXPLD11</b> | USBD_BA+0x5B4 | R/W | Endpoint 11 Maximal Payload Register | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [8:0]  | MXPLD       | <p><b>Maximal Payload</b><br/> Define the data length which is transmitted to host (IN token) or the actual data length which is received from the host (OUT token). It also used to indicate that the endpoint is ready to be transmitted in IN token or received in OUT token.</p> <p>(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 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 the maximal data length comes from host.</p> <p>(2) When the register is read by CPU,</p> |

|  |  |                                                                                                                                                                                                                                                                                                                    |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | For IN token, the value of MXPLD is indicated by the data length be transmitted to host<br>For OUT token, the value of MXPLD is indicated the actual data length receiving from host.<br><b>Note:</b> Once MXPLD is written, the data packets will be transmitted/received immediately after IN/OUT token arrived. |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

USB Configuration Register (USB\_CFGx)

| Register          | Offset        | R/W | Description                        |  |  |  | Reset Value |
|-------------------|---------------|-----|------------------------------------|--|--|--|-------------|
| <b>USBD_CFG0</b>  | USBD_BA+0x508 | R/W | Endpoint 0 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG1</b>  | USBD_BA+0x518 | R/W | Endpoint 1 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG2</b>  | USBD_BA+0x528 | R/W | Endpoint 2 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG3</b>  | USBD_BA+0x538 | R/W | Endpoint 3 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG4</b>  | USBD_BA+0x548 | R/W | Endpoint 4 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG5</b>  | USBD_BA+0x558 | R/W | Endpoint 5 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG6</b>  | USBD_BA+0x568 | R/W | Endpoint 6 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG7</b>  | USBD_BA+0x578 | R/W | Endpoint 7 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG8</b>  | USBD_BA+0x588 | R/W | Endpoint 8 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG9</b>  | USBD_BA+0x598 | R/W | Endpoint 9 Configuration Register  |  |  |  | 0x0000_0000 |
| <b>USBD_CFG10</b> | USBD_BA+0x5A8 | R/W | Endpoint 10 Configuration Register |  |  |  | 0x0000_0000 |
| <b>USBD_CFG11</b> | 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      | <b>Clear STALL Response</b><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     | <b>Data Sequence Synchronization</b><br>0 = DATA0 PID.<br>1 = DATA1 PID.<br><b>Note:</b> It is used to specify the DATA0 or DATA1 PID in the following IN token transaction. hardware will toggle automatically in IN token base on the bit. |

|       |              |                                                                                                                                                                         |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6:5] | <b>STATE</b> | <b>Endpoint STATE</b><br>00 = Endpoint is Disabled.<br>01 = Out endpoint.<br>10 = IN endpoint.<br>11 = Undefined.                                                       |
| [4]   | <b>ISOCH</b> | <b>Isochronous Endpoint</b><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] | <b>EPNUM</b> | <b>Endpoint Number</b><br>These bits are used to define the endpoint number of the current endpoint                                                                     |

USB Extra Configuration Register (USB\_CFGPx)

| Register           | Offset        | R/W | Description                                                   | Reset Value |
|--------------------|---------------|-----|---------------------------------------------------------------|-------------|
| <b>USBD_CFGP0</b>  | USBD_BA+0x50C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP1</b>  | USBD_BA+0x51C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP2</b>  | USBD_BA+0x52C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP3</b>  | USBD_BA+0x53C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP4</b>  | USBD_BA+0x54C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP5</b>  | USBD_BA+0x55C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP6</b>  | USBD_BA+0x56C | R/W | Endpoint 6 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP7</b>  | USBD_BA+0x57C | R/W | Endpoint 7 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP8</b>  | USBD_BA+0x58C | R/W | Endpoint 8 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP9</b>  | USBD_BA+0x59C | R/W | Endpoint 9 Set Stall and Clear In/Out Ready Control Register  | 0x0000_0000 |
| <b>USBD_CFGP10</b> | USBD_BA+0x5AC | R/W | Endpoint 10 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| <b>USBD_CFGP11</b> | USBD_BA+0x5BC | R/W | Endpoint 11 Set Stall and Clear In/Out Ready 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 |    |    |    |    |    | SSTALL | CLRRDY |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [1]    | SSTALL      | <b>Set STALL</b><br>0 = Disable the device to response STALL.<br>1 = Set the device to respond STALL automatically.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [0]    | CLRRDY      | <b>Clear Ready</b><br>When the USBD_MXPLDx register is set by user, it means that the endpoint is ready to transmit or receive data. If the user wants to disable this transaction before the transaction start, users can set this bit to 1 to disable it and it is auto clear to 0.<br>For IN token, write '1' to clear the IN token had ready to transmit the data to USB.<br>For OUT token, write '1' to clear the OUT token had ready to receive the data from USB.<br>This bit is write 1 only and is always 0 when it is read back. |

## 6.31 High Speed USB 2.0 Device Controller (HSUSBD)

### 6.31.1 Overview

The USB device controller interfaces the AHB bus and the UTMI bus. The USB controller contains both the AHB master interface and AHB slave interface. CPU programs the USB controller registers through the AHB slave interface. For IN or OUT transfer, the USB device controller needs to write data to memory or read data from memory through the AHB master interface. The USB device controller is complaint with USB 2.0 specification and it contains 12 configurable endpoints in addition to control endpoint. These endpoints could be configured to BULK, INTERRUPT or ISO. The USB device controller has a built-in DMA to relieve the load of CPU.

### 6.31.2 Features

- USB Specification reversion 2.0 compliant
- Supports 12 configurable endpoints in addition to Control Endpoint
- Each of the endpoints can be Isochronous, Bulk or Interrupt and either IN or OUT direction
- Three different operation modes of an in-endpoint — Auto Validation mode, Manual Validation mode, Fly mode
- Supports DMA operation
- 4092 Bytes Configurable RAM used as endpoint buffer
- Supports Endpoint Maximum Packet Size up to 1024 bytes

### 6.31.3 Block Diagram



Figure 6.31-1 USB Device Controller Block Diagram

### 6.31.4 Basic Configuration

- Clock Source Configuration
  - Enable HSUSBD clock in HSUSBDCKEN (CLK\_AHBCLOCK[10]).
- Reset Configuration
  - Reset HSUSBD controller in HSUSBDRST (SYS\_IPRST0[10]).

### 6.31.5 Functional Description

#### 6.31.5.1 Operation of Different In-transfer Modes

The data for any in-transfer is written into the internal buffer when in turn is sent to the host on receipt of an in-token. There are three different modes by which the data sent to the host is validated by CPU.

- Auto-Validation Mode
- Manual-Validation Mode
- Fly Mode

#### 6.31.5.2 Auto-Validation Mode

If an endpoint is selected to be operating in auto-validation mode, the endpoint responds only with data payload to be equal to EPMPS register. The endpoint controller wait until the amount of data is equal to EPMPS value and then validates the data. If CPU needs to send a short-packet at the end of a transfer, the SHORTTXEN bit of HSUSBD\_EPxRSPCTL[6] should be set. When this bit set, any remaining data in the buffer is validated and is sent to the host, for the forthcoming in-token.

This mode requires least intervention of CPU, as most of the work is done by the USB device controller. The mode can be selected, when the data payload sent to host is always equal to MPS size.

| SHORTTXEN | Data Availability In Buffer | Data Sent/NAK Sent                    |
|-----------|-----------------------------|---------------------------------------|
| 0         | < Max. Packet Size          | NAK sent                              |
| 0         | >= Max. Packet Size         | Data payload of max. packet size      |
| 1         | < Max. Packet Size          | Available data of < max. packet size  |
| 1         | >= Max. Packet Size         | Data payload of max. packet size sent |

#### 6.31.5.3 Manual-Validation Mode

If the endpoint is selected to be operating in manual-validation mode, the endpoint responds only when the data in the buffer is validated by CPU every time. The CPU has to write data into the buffer and then write the count of the data into EPxTxCNT register. Once the data is validating by writing a count into the EPxTxCNT register, the data is sent to the host on receipt of an in-token.

This mode requires intervention of CPU for each transfer. But this would be useful, if the data-count to be sent each time is not fixed, and it is being decided by CPU.

| EPxTxCNT Written | Data Availability In Buffer | Data Sent/NAK Sent            |
|------------------|-----------------------------|-------------------------------|
| NO               | -                           | NAK                           |
| YES              | EPxTxCNT                    | Data payload of EPxTxCNT sent |

#### 6.31.5.4 Fly Mode

The fly mode of operation is simplest mode of operation, where there is no validation procedure. The buffer is being filled by CPU. If an in-token is send from the host, the data in the buffer is automatically validated and sent to the host. If the data in the buffer spans more than one packet of maximum packet size, the controller automatically packs to equal to MPS and send it to the host.

This mode requires the least intervention by CPU. This mode is best suited for isochronous data transfer, where the speed of data transfer is more important than the packet size.

| Data Availability In Buffer | Data Sent                              |
|-----------------------------|----------------------------------------|
| < Max. Packet Size          | Data available sent                    |
| >= Max. Packet Size         | Data payload of max. packet size sent. |

### 6.31.5.5 Scatter-Gather Function

User enables DMA scatter gather function by setting SGEN (HSUSBD\_DMACTL[6]) =1, and sets HSUSBD\_DMACNT as 8 bytes, and the memory address and length will be recorded in the descriptor. The format is shown in Table 6.31-1.

|       | Format         |      |             |
|-------|----------------|------|-------------|
|       | [31]           | [30] | [29:0]      |
| Word0 | MEM_ADDR[31:0] |      |             |
| Word1 | EOT            | RD   | Reserved    |
|       |                |      | Count[19:0] |

Table 6.31-1 Scatter Gather Descriptor Format

**MEM\_ADDR:** It specifies the memory address (AHB address).

**EOT:** end of transfer. When this bit is set to high, it means this is the last descriptor.

**RD:** “1” means read from memory into buffer. “0” means read from buffer into memory.

### 6.31.6 Registers Map

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

| Register                       | Offset          | R/W | Description                                 | Reset Value |
|--------------------------------|-----------------|-----|---------------------------------------------|-------------|
| <b>USBD Base Address:</b>      |                 |     |                                             |             |
| <b>HSUSBD_BA = 0x4001_9000</b> |                 |     |                                             |             |
| HSUSBD_GINTSTS                 | HSUSBD_BA+0x000 | R   | Global Interrupt Status Register            | 0x0000_0000 |
| HSUSBD_GINTEN                  | HSUSBD_BA+0x008 | R/W | Global Interrupt Enable Register            | 0x0000_0001 |
| HSUSBD_BUSINTSTS               | HSUSBD_BA+0x010 | R/W | USB Bus Interrupt Status Register           | 0x0000_0000 |
| HSUSBD_BUSINTEN                | HSUSBD_BA+0x014 | R/W | USB Bus Interrupt Enable Register           | 0x0000_0040 |
| HSUSBD_OPER                    | HSUSBD_BA+0x018 | R/W | USB Operational Register                    | 0x0000_0002 |
| HSUSBD_FRAMECNT                | HSUSBD_BA+0x01C | R   | USB Frame Count Register                    | 0x0000_0000 |
| HSUSBD_FADDR                   | HSUSBD_BA+0x020 | R/W | USB Function Address Register               | 0x0000_0000 |
| HSUSBD_TEST                    | HSUSBD_BA+0x024 | R/W | USB Test Mode Register                      | 0x0000_0000 |
| HSUSBD_CEPDAT                  | HSUSBD_BA+0x028 | R/W | Control-Endpoint Data Buffer                | 0x0000_0000 |
| HSUSBD_CEPCTL                  | HSUSBD_BA+0x02C | R/W | Control-Endpoint Control Register           | 0x0000_0000 |
| HSUSBD_CEPINTEN                | HSUSBD_BA+0x030 | R/W | Control-Endpoint Interrupt Enable           | 0x0000_0000 |
| HSUSBD_CEPINTSTS               | HSUSBD_BA+0x034 | R/W | Control-Endpoint Interrupt Status           | 0x0000_1800 |
| HSUSBD_CEPTXCNT                | HSUSBD_BA+0x038 | R/W | Control-Endpoint In-transfer Data Count     | 0x0000_0000 |
| HSUSBD_CEPRXCN                 | HSUSBD_BA+0x03C | R   | Control-Endpoint Out-transfer Data Count    | 0x0000_0000 |
| HSUSBD_CEPDATCNT               | HSUSBD_BA+0x040 | R   | Control-Endpoint data count                 | 0x0000_0000 |
| HSUSBD_SETUP1_0                | HSUSBD_BA+0x044 | R   | Setup1 & Setup0 bytes                       | 0x0000_0000 |
| HSUSBD_SETUP3_2                | HSUSBD_BA+0x048 | R   | Setup3 & Setup2 Bytes                       | 0x0000_0000 |
| HSUSBD_SETUP5_4                | HSUSBD_BA+0x04C | R   | Setup5 & Setup4 Bytes                       | 0x0000_0000 |
| HSUSBD_SETUP7_6                | HSUSBD_BA+0x050 | R   | Setup7 & Setup6 Bytes                       | 0x0000_0000 |
| HSUSBD_CEPBUFSTART             | HSUSBD_BA+0x054 | R/W | Control Endpoint RAM Start Address Register | 0x0000_0000 |
| HSUSBD_CEPBUFEND               | HSUSBD_BA+0x058 | R/W | Control Endpoint RAM End Address Register   | 0x0000_0000 |
| HSUSBD_DMACTL                  | HSUSBD_BA+0x05C | R/W | DMA Control Status Register                 | 0x0000_0000 |
| HSUSBD_DMACNT                  | HSUSBD_BA+0x060 | R/W | DMA Count Register                          | 0x0000_0000 |
| HSUSBD_EPADAT                  | HSUSBD_BA+0x064 | R/W | Endpoint A Data Register                    | 0x0000_0000 |
| HSUSBD_EPAINTSTS               | HSUSBD_BA+0x068 | R/W | Endpoint A Interrupt Status Register        | 0x0000_0003 |
| HSUSBD_EPAINTEN                | HSUSBD_BA+0x06C | R/W | Endpoint A Interrupt Enable Register        | 0x0000_0000 |
| HSUSBD_EPADATCNT               | HSUSBD_BA+0x070 | R   | Endpoint A Data Available Count Register    | 0x0000_0000 |
| HSUSBD_EPARSPCTL               | HSUSBD_BA+0x074 | R/W | Endpoint A Response Control Register        | 0x0000_0000 |
| HSUSBD_EPAMPS                  | HSUSBD_BA+0x078 | R/W | Endpoint A Maximum Packet Size              | 0x0000_0000 |

|                    |                 |     | Register                                 |             |
|--------------------|-----------------|-----|------------------------------------------|-------------|
| HSUSBD_EPATXCNT    | HSUSBD_BA+0x07C | R/W | Endpoint A Transfer Count Register       | 0x0000_0000 |
| HSUSBD_EPACFG      | HSUSBD_BA+0x080 | R/W | Endpoint A Configuration Register        | 0x0000_0012 |
| HSUSBD_EPABUFSTART | HSUSBD_BA+0x084 | R/W | Endpoint A RAM Start Address Register    | 0x0000_0000 |
| HSUSBD_EPABUFEND   | HSUSBD_BA+0x088 | R/W | Endpoint A RAM End Address Register      | 0x0000_0000 |
| HSUSBD_EPBDAT      | HSUSBD_BA+0x08C | R/W | Endpoint B Data Register                 | 0x0000_0000 |
| HSUSBD_EPBINTSTS   | HSUSBD_BA+0x090 | R/W | Endpoint B Interrupt Status Register     | 0x0000_0003 |
| HSUSBD_EPBINTEN    | HSUSBD_BA+0x094 | R/W | Endpoint B Interrupt Enable Register     | 0x0000_0000 |
| HSUSBD_EPBDAUTCNT  | HSUSBD_BA+0x098 | R   | Endpoint B Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPBRSPCTL   | HSUSBD_BA+0x09C | R/W | Endpoint B Response Control Register     | 0x0000_0000 |
| HSUSBD_EPBMPMS     | HSUSBD_BA+0x0A0 | R/W | Endpoint B Maximum Packet Size Register  | 0x0000_0000 |
| HSUSBD_EPBTXCNT    | HSUSBD_BA+0x0A4 | R/W | Endpoint B Transfer Count Register       | 0x0000_0000 |
| HSUSBD_EPBCFG      | HSUSBD_BA+0x0A8 | R/W | Endpoint B Configuration Register        | 0x0000_0022 |
| HSUSBD_EPBBUFSTART | HSUSBD_BA+0x0AC | R/W | Endpoint B RAM Start Address Register    | 0x0000_0000 |
| HSUSBD_EPBBUFEND   | HSUSBD_BA+0x0B0 | R/W | Endpoint B RAM End Address Register      | 0x0000_0000 |
| HSUSBD_EPCDAT      | HSUSBD_BA+0x0B4 | R/W | Endpoint C Data Register                 | 0x0000_0000 |
| HSUSBD_EPCINTSTS   | HSUSBD_BA+0x0B8 | R/W | Endpoint C Interrupt Status Register     | 0x0000_0003 |
| HSUSBD_EPCINTEN    | HSUSBD_BA+0x0BC | R/W | Endpoint C Interrupt Enable Register     | 0x0000_0000 |
| HSUSBD_EPCDATCNT   | HSUSBD_BA+0x0C0 | R   | Endpoint C Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPCRSPCTL   | HSUSBD_BA+0x0C4 | R/W | Endpoint C Response Control Register     | 0x0000_0000 |
| HSUSBD_EPCMPS      | HSUSBD_BA+0x0C8 | R/W | Endpoint C Maximum Packet Size Register  | 0x0000_0000 |
| HSUSBD_EPCTXCNT    | HSUSBD_BA+0x0CC | R/W | Endpoint C Transfer Count Register       | 0x0000_0000 |
| HSUSBD_EPCCFG      | HSUSBD_BA+0x0D0 | R/W | Endpoint C Configuration Register        | 0x0000_0032 |
| HSUSBD_EPCBUFSTART | HSUSBD_BA+0x0D4 | R/W | Endpoint C RAM Start Address Register    | 0x0000_0000 |
| HSUSBD_EPCBUFEND   | HSUSBD_BA+0x0D8 | R/W | Endpoint C RAM End Address Register      | 0x0000_0000 |
| HSUSBD_EPDDAT      | HSUSBD_BA+0x0DC | R/W | Endpoint D Data Register                 | 0x0000_0000 |
| HSUSBD_EPDINTSTS   | HSUSBD_BA+0x0E0 | R/W | Endpoint D Interrupt Status Register     | 0x0000_0003 |
| HSUSBD_EPDINTEN    | HSUSBD_BA+0x0E4 | R/W | Endpoint D Interrupt Enable Register     | 0x0000_0000 |
| HSUSBD_EPDDATCNT   | HSUSBD_BA+0x0E8 | R   | Endpoint D Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPDRSPCTL   | HSUSBD_BA+0x0EC | R/W | Endpoint D Response Control Register     | 0x0000_0000 |
| HSUSBD_EPDMPMS     | HSUSBD_BA+0x0F0 | R/W | Endpoint D Maximum Packet Size Register  | 0x0000_0000 |
| HSUSBD_EPDTXCNT    | HSUSBD_BA+0x0F4 | R/W | Endpoint D Transfer Count Register       | 0x0000_0000 |

|                           |                 |     |                                          |             |
|---------------------------|-----------------|-----|------------------------------------------|-------------|
| <b>HSUSBD_EPDCFG</b>      | HSUSBD_BA+0x0F8 | R/W | Endpoint D Configuration Register        | 0x0000_0042 |
| <b>HSUSBD_EPDBUFSTART</b> | HSUSBD_BA+0x0FC | R/W | Endpoint D RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPDBUFEND</b>   | HSUSBD_BA+0x100 | R/W | Endpoint D RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPEDAT</b>      | HSUSBD_BA+0x104 | R/W | Endpoint E Data Register                 | 0x0000_0000 |
| <b>HSUSBD_EPEINTSTS</b>   | HSUSBD_BA+0x108 | R/W | Endpoint E Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPEINTEN</b>    | HSUSBD_BA+0x10C | R/W | Endpoint E Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPEDATCNT</b>   | HSUSBD_BA+0x110 | R   | Endpoint E Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EPERSPCTL</b>   | HSUSBD_BA+0x114 | R/W | Endpoint E Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPEMPS</b>      | HSUSBD_BA+0x118 | R/W | Endpoint E Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPETXCNT</b>    | HSUSBD_BA+0x11C | R/W | Endpoint E Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPECFG</b>      | HSUSBD_BA+0x120 | R/W | Endpoint E Configuration Register        | 0x0000_0052 |
| <b>HSUSBD_EPEBUFSTART</b> | HSUSBD_BA+0x124 | R/W | Endpoint E RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPEBUFEND</b>   | HSUSBD_BA+0x128 | R/W | Endpoint E RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPFDAT</b>      | HSUSBD_BA+0x12C | R/W | Endpoint F Data Register                 | 0x0000_0000 |
| <b>HSUSBD_EPFINTSTS</b>   | HSUSBD_BA+0x130 | R/W | Endpoint F Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPFINTEN</b>    | HSUSBD_BA+0x134 | R/W | Endpoint F Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPFDATCNT</b>   | HSUSBD_BA+0x138 | R   | Endpoint F Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EPFRSPCTL</b>   | HSUSBD_BA+0x13C | R/W | Endpoint F Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPFMPS</b>      | HSUSBD_BA+0x140 | R/W | Endpoint F Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPFTXCNT</b>    | HSUSBD_BA+0x144 | R/W | Endpoint F Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPFCFG</b>      | HSUSBD_BA+0x148 | R/W | Endpoint F Configuration Register        | 0x0000_0062 |
| <b>HSUSBD_EPFBUFSTART</b> | HSUSBD_BA+0x14C | R/W | Endpoint F RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPFBUFEND</b>   | HSUSBD_BA+0x150 | R/W | Endpoint F RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPGDAT</b>      | HSUSBD_BA+0x154 | R/W | Endpoint G Data Register                 | 0x0000_0000 |
| <b>HSUSBD_EPGINTSTS</b>   | HSUSBD_BA+0x158 | R/W | Endpoint G Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPGINTEN</b>    | HSUSBD_BA+0x15C | R/W | Endpoint G Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPGDATCNT</b>   | HSUSBD_BA+0x160 | R   | Endpoint G Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EGPRSPCTL</b>   | HSUSBD_BA+0x164 | R/W | Endpoint G Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPGMPS</b>      | HSUSBD_BA+0x168 | R/W | Endpoint G Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPGTXCNT</b>    | HSUSBD_BA+0x16C | R/W | Endpoint G Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPGCFG</b>      | HSUSBD_BA+0x170 | R/W | Endpoint G Configuration Register        | 0x0000_0072 |
| <b>HSUSBD_EPGBUFSTART</b> | HSUSBD_BA+0x174 | R/W | Endpoint G RAM Start Address Register    | 0x0000_0000 |

|                           |                 |     |                                          |             |
|---------------------------|-----------------|-----|------------------------------------------|-------------|
| <b>HSUSBD_EPGBUFEND</b>   | HSUSBD_BA+0x178 | R/W | Endpoint G RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPHDAT</b>      | HSUSBD_BA+0x17C | R/W | Endpoint H Data Register                 | 0x0000_0000 |
| <b>HSUSBD_EPHINTSTS</b>   | HSUSBD_BA+0x180 | R/W | Endpoint H Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPHINTEN</b>    | HSUSBD_BA+0x184 | R/W | Endpoint H Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPHDATCNT</b>   | HSUSBD_BA+0x188 | R   | Endpoint H Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EPHRSPCTL</b>   | HSUSBD_BA+0x18C | R/W | Endpoint H Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPHMPS</b>      | HSUSBD_BA+0x190 | R/W | Endpoint H Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPHTXCNT</b>    | HSUSBD_BA+0x194 | R/W | Endpoint H Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPHCFG</b>      | HSUSBD_BA+0x198 | R/W | Endpoint H Configuration Register        | 0x0000_0082 |
| <b>HSUSBD_EPHBUFSTART</b> | HSUSBD_BA+0x19C | R/W | Endpoint H RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPHBUFEND</b>   | HSUSBD_BA+0x1A0 | R/W | Endpoint H RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPIDAT</b>      | HSUSBD_BA+0x1A4 | R/W | Endpoint I Data Register                 | 0x0000_0000 |
| <b>HSUSBD_EPIINTSTS</b>   | HSUSBD_BA+0x1A8 | R/W | Endpoint I Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPIINTEN</b>    | HSUSBD_BA+0x1AC | R/W | Endpoint I Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPIDATCNT</b>   | HSUSBD_BA+0x1B0 | R   | Endpoint I Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EPIRSPCTL</b>   | HSUSBD_BA+0x1B4 | R/W | Endpoint I Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPIMPS</b>      | HSUSBD_BA+0x1B8 | R/W | Endpoint I Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPITXCNT</b>    | HSUSBD_BA+0x1BC | R/W | Endpoint I Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPICFG</b>      | HSUSBD_BA+0x1C0 | R/W | Endpoint I Configuration Register        | 0x0000_0092 |
| <b>HSUSBD_EPIBUFSTART</b> | HSUSBD_BA+0x1C4 | R/W | Endpoint I RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPIBUFEND</b>   | HSUSBD_BA+0x1C8 | R/W | Endpoint I RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPJDAT</b>      | HSUSBD_BA+0x1CC | R/W | Endpoint J Data Register                 | 0x0000_0000 |
| <b>HSUSBD_EPJINTSTS</b>   | HSUSBD_BA+0x1D0 | R/W | Endpoint J Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPJINTEN</b>    | HSUSBD_BA+0x1D4 | R/W | Endpoint J Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPJDATCNT</b>   | HSUSBD_BA+0x1D8 | R   | Endpoint J Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EPJRSPCTL</b>   | HSUSBD_BA+0x1DC | R/W | Endpoint J Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPJmps</b>      | HSUSBD_BA+0x1E0 | R/W | Endpoint J Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPJTXCNT</b>    | HSUSBD_BA+0x1E4 | R/W | Endpoint J Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPJCFG</b>      | HSUSBD_BA+0x1E8 | R/W | Endpoint J Configuration Register        | 0x0000_00A2 |
| <b>HSUSBD_EPJBUFSTART</b> | HSUSBD_BA+0x1EC | R/W | Endpoint J RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPJBUFEND</b>   | HSUSBD_BA+0x1F0 | R/W | Endpoint J RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPKDAT</b>      | HSUSBD_BA+0x1F4 | R/W | Endpoint K Data Register                 | 0x0000_0000 |

|                           |                 |     |                                          |             |
|---------------------------|-----------------|-----|------------------------------------------|-------------|
| <b>HSUSBD_EPKINTSTS</b>   | HSUSBD_BA+0x1F8 | R/W | Endpoint K Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPKINTEN</b>    | HSUSBD_BA+0x1FC | R/W | Endpoint K Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPKDATCNT</b>   | HSUSBD_BA+0x200 | R   | Endpoint K Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EPKRSPCTL</b>   | HSUSBD_BA+0x204 | R/W | Endpoint K Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPKMPS</b>      | HSUSBD_BA+0x208 | R/W | Endpoint K Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPKTXCNT</b>    | HSUSBD_BA+0x20C | R/W | Endpoint K Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPKCFG</b>      | HSUSBD_BA+0x210 | R/W | Endpoint K Configuration Register        | 0x0000_00B2 |
| <b>HSUSBD_EPKBUFSTART</b> | HSUSBD_BA+0x214 | R/W | Endpoint K RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPKBUFEND</b>   | HSUSBD_BA+0x218 | R/W | Endpoint K RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_EPLDAT</b>      | HSUSBD_BA+0x21C | R/W | Endpoint L Data Register                 | 0x0000_0000 |
| <b>HSUSBD_EPLINTSTS</b>   | HSUSBD_BA+0x220 | R/W | Endpoint L Interrupt Status Register     | 0x0000_0003 |
| <b>HSUSBD_EPLINTEN</b>    | HSUSBD_BA+0x224 | R/W | Endpoint L Interrupt Enable Register     | 0x0000_0000 |
| <b>HSUSBD_EPLDATCNT</b>   | HSUSBD_BA+0x228 | R   | Endpoint L Data Available Count Register | 0x0000_0000 |
| <b>HSUSBD_EPLRSPCTL</b>   | HSUSBD_BA+0x22C | R/W | Endpoint L Response Control Register     | 0x0000_0000 |
| <b>HSUSBD_EPLMPS</b>      | HSUSBD_BA+0x230 | R/W | Endpoint L Maximum Packet Size Register  | 0x0000_0000 |
| <b>HSUSBD_EPLTXCNT</b>    | HSUSBD_BA+0x234 | R/W | Endpoint L Transfer Count Register       | 0x0000_0000 |
| <b>HSUSBD_EPLCFG</b>      | HSUSBD_BA+0x238 | R/W | Endpoint L Configuration Register        | 0x0000_00C2 |
| <b>HSUSBD_EPLBUFSTART</b> | HSUSBD_BA+0x23C | R/W | Endpoint L RAM Start Address Register    | 0x0000_0000 |
| <b>HSUSBD_EPLBUFEND</b>   | HSUSBD_BA+0x240 | R/W | Endpoint L RAM End Address Register      | 0x0000_0000 |
| <b>HSUSBD_DMAADDR</b>     | HSUSBD_BA+0x700 | R/W | AHB DMA Address Register                 | 0x0000_0000 |
| <b>HSUSBD_PHYCTL</b>      | HSUSBD_BA+0x704 | R/W | USB PHY Control Register                 | 0x0000_0420 |

### 6.31.7 Register Description

#### Global Interrupt Status Register (HSUSBD\_GINTSTS)

| Register       | Offset          | R/W | Description                      |  |  |  | Reset Value |
|----------------|-----------------|-----|----------------------------------|--|--|--|-------------|
| HSUSBD_GINTSTS | HSUSBD_BA+0x000 | R   | Global 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 |       | EPLIF | EPKIF | EPJIF | EPIIF | EPHIF | EPGIF |
| 7        | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| EPFIF    | EPEIF | EPDIF | EPCIF | EPBIF | EPAIF | CEPIF | USBIF |

| Bits    | Description |                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                     |
| [13]    | EPLIF       | <p><b>Endpoint L Interrupt</b></p> <p>When set, the corresponding Endpoint L's interrupt status register should be read to determine the cause of the interrupt.</p> <p>0 = No interrupt event occurred.</p> <p>1 = The related interrupt event occurred.</p> |
| [12]    | EPKIF       | <p><b>Endpoint K Interrupt</b></p> <p>When set, the corresponding Endpoint K's interrupt status register should be read to determine the cause of the interrupt.</p> <p>0 = No interrupt event occurred.</p> <p>1 = The related interrupt event occurred.</p> |
| [11]    | EPJIF       | <p><b>Endpoint J Interrupt</b></p> <p>When set, the corresponding Endpoint J's interrupt status register should be read to determine the cause of the interrupt.</p> <p>0 = No interrupt event occurred.</p> <p>1 = The related interrupt event occurred.</p> |
| [10]    | EPIIF       | <p><b>Endpoint I Interrupt</b></p> <p>When set, the corresponding Endpoint I's interrupt status register should be read to determine the cause of the interrupt.</p> <p>0 = No interrupt event occurred.</p> <p>1 = The related interrupt event occurred.</p> |
| [9]     | EPHIF       | <p><b>Endpoint H Interrupt</b></p> <p>When set, the corresponding Endpoint H's interrupt status register should be read to determine the cause of the interrupt.</p> <p>0 = No interrupt event occurred.</p> <p>1 = The related interrupt event occurred.</p> |

|     |              |                                                                                                                                                                                                                                                                                            |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8] | <b>EPGIF</b> | <b>Endpoint G Interrupt</b><br>When set, the corresponding Endpoint G's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.                                                 |
| [7] | <b>EPFIF</b> | <b>Endpoint F Interrupt</b><br>When set, the corresponding Endpoint F's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.                                                 |
| [6] | <b>EPEIF</b> | <b>Endpoint E Interrupt</b><br>When set, the corresponding Endpoint E's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.                                                 |
| [5] | <b>EPDIF</b> | <b>Endpoint D Interrupt</b><br>When set, the corresponding Endpoint D's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.                                                 |
| [4] | <b>EPCIF</b> | <b>Endpoint C Interrupt</b><br>When set, the corresponding Endpoint C's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.                                                 |
| [3] | <b>EPBIF</b> | <b>Endpoint B Interrupt</b><br>When set, the corresponding Endpoint B's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.                                                 |
| [2] | <b>EPAIF</b> | <b>Endpoint a Interrupt</b><br>When set, the corresponding Endpoint A's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.                                                 |
| [1] | <b>CEPIF</b> | <b>Control Endpoint Interrupt</b><br>This bit conveys the interrupt status for control endpoint. When set, Control-ep's interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred. |
| [0] | <b>USBIF</b> | <b>USB Interrupt</b><br>This bit conveys the interrupt status for USB specific events endpoint. When set, USB interrupt status register should be read to determine the cause of the interrupt.<br>0 = No interrupt event occurred.<br>1 = The related interrupt event occurred.           |

**Global Interrupt Enable Register (HSUSBD\_GINTEN)**

| Register      | Offset          | R/W | Description                      |  |  |  | Reset Value |
|---------------|-----------------|-----|----------------------------------|--|--|--|-------------|
| HSUSBD_GINTEN | HSUSBD_BA+0x008 | R/W | Global Interrupt Enable Register |  |  |  | 0x0000_0001 |

|          |        |        |        |        |        |        |        |
|----------|--------|--------|--------|--------|--------|--------|--------|
| 31       | 30     | 29     | 28     | 27     | 26     | 25     | 24     |
| Reserved |        |        |        |        |        |        |        |
| 23       | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
| Reserved |        |        |        |        |        |        |        |
| 15       | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| Reserved |        | EPLIEN | EPKIEN | EPJIEN | EPIIEN | EPHIEN | EPGIEN |
| 7        | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| EPFIEN   | EPEIEN | EPDIEN | EPCIEN | EPBIEN | EPAIEN | CEPIEN | USBIEN |

| Bits    | Description |                                                                                                                                                                                                                                             |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                   |
| [13]    | EPLIEN      | <b>Interrupt Enable Control for Endpoint L</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint L<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled. |
| [12]    | EPKIEN      | <b>Interrupt Enable Control for Endpoint K</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint K<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled. |
| [11]    | EPJIEN      | <b>Interrupt Enable Control for Endpoint J</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint J<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled. |
| [10]    | EPIIEN      | <b>Interrupt Enable Control for Endpoint I</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint I<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled. |
| [9]     | EPHIEN      | <b>Interrupt Enable Control for Endpoint H</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint H<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled. |

|     |               |                                                                                                                                                                                                                                                  |
|-----|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8] | <b>EPGIEN</b> | <b>Interrupt Enable Control for Endpoint G</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint G<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.      |
| [7] | <b>EPFIEN</b> | <b>Interrupt Enable Control for Endpoint F</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint F<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.      |
| [6] | <b>EPEIEN</b> | <b>Interrupt Enable Control for Endpoint E</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint E<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.      |
| [5] | <b>EPDIEN</b> | <b>Interrupt Enable Control for Endpoint D</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint D<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.      |
| [4] | <b>EPCIEN</b> | <b>Interrupt Enable Control for Endpoint C</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint C<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.      |
| [3] | <b>EPBIEN</b> | <b>Interrupt Enable Control for Endpoint B</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint B<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.      |
| [2] | <b>EPAIEN</b> | <b>Interrupt Enable Control for Endpoint a</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the endpoint A.<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.     |
| [1] | <b>CEPIEN</b> | <b>Control Endpoint Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be generated when an interrupt is pending for the control endpoint.<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled. |
| [0] | <b>USBIEN</b> | <b>USB Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be generated when a USB event occurs on the bus.<br>0 = The related interrupt Disabled.<br>1 = The related interrupt Enabled.                                 |

USB Bus Interrupt Status Register (HSUSBD\_BUSINTSTS)

| Register         | Offset          | R/W | Description                       |  |  | Reset Value |
|------------------|-----------------|-----|-----------------------------------|--|--|-------------|
| HSUSBD_BUSINTSTS | HSUSBD_BA+0x010 | R/W | USB Bus 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 |             |           |         |           |          |       | VBUSDETIF |
| 7        | 6           | 5         | 4       | 3         | 2        | 1     | 0         |
| Reserved | PHYCLKVLDIF | DMADONEIF | HISPDIF | SUSPENDIF | RESUMEIF | RSTIF | SOFIF     |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [8]    | VBUSDETIF   | <b>VBUS Detection Interrupt Status</b><br>0 = No VBUS is plug-in.<br>1 = VBUS is plug-in.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                                                      |
| [7]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |
| [6]    | PHYCLKVLDIF | <b>Usable Clock Interrupt</b><br>0 = Usable clock is not available.<br>1 = Usable clock is available from the transceiver.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                     |
| [5]    | DMADONEIF   | <b>DMA Completion Interrupt</b><br>0 = No DMA transfer over.<br>1 = DMA transfer is over.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                                                      |
| [4]    | HISPDIF     | <b>High-speed Settle</b><br>0 = No valid high-speed reset protocol is detected.<br>1 = Valid high-speed reset protocol is over and the device has settled in high-speed.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                       |
| [3]    | SUSPENDIF   | <b>Suspend Request</b><br>This bit is set as default and it has to be cleared by writing '1' before the USB reset.<br>This bit is also set when a USB Suspend request is detected from the host.<br>0 = No USB Suspend request is detected from the host.<br>1= USB Suspend request is detected from the host.<br><b>Note:</b> Write 1 to clear this bit to 0. |

|     |                 |                                                                                                                                                                                                                                                     |
|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>RESUMEIF</b> | <b>Resume</b><br>When set, this bit indicates that a device resume has occurred.<br>0 = No device resume has occurred.<br>1 = Device resume has occurred.<br><b>Note:</b> Write 1 to clear this bit to 0.                                           |
| [1] | <b>RSTIF</b>    | <b>Reset Status</b><br>When set, this bit indicates that either the USB root port reset is end.<br>0 = No USB root port reset is end.<br>1 = USB root port reset is end.<br><b>Note:</b> Write 1 to clear this bit to 0.                            |
| [0] | <b>SOFIF</b>    | <b>SOF Receive Control</b><br>This bit indicates when a start-of-frame packet has been received.<br>0 = No start-of-frame packet has been received.<br>1 = Start-of-frame packet has been received.<br><b>Note:</b> Write 1 to clear this bit to 0. |

**USB Bus Interrupt Enable Register (HSUSBD\_BUSINTEN)**

| Register        | Offset          | R/W | Description                       |  |  |  |  | Reset Value |
|-----------------|-----------------|-----|-----------------------------------|--|--|--|--|-------------|
| HSUSBD_BUSINTEN | HSUSBD_BA+0x014 | R/W | USB Bus Interrupt Enable 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 |                  |            |          |                |           |        | VBUSDETIEN |
| 7        | 6                | 5          | 4        | 3              | 2         | 1      | 0          |
| Reserved | PHYCLKVLDIE<br>N | DMADONEIEN | HISPDien | SUSPENDIE<br>N | RESUMEIEN | RSTIEN | SOFIEN     |

| Bits   | Description    |                                                                                                                                                                                                            |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved       | Reserved.                                                                                                                                                                                                  |
| [8]    | VBUSDETIEN     | <b>VBUS Detection Interrupt Enable Bit</b><br>This bit enables the VBUS floating detection interrupt.<br>0 = VBUS floating detection interrupt Disabled.<br>1 = VBUS floating detection interrupt Enabled. |
| [7]    | Reserved       | Reserved.                                                                                                                                                                                                  |
| [6]    | PHYCLKVLDIEN   | <b>Usable Clock Interrupt</b><br>This bit enables the usable clock interrupt.<br>0 = Usable clock interrupt Disabled.<br>1 = Usable clock interrupt Enabled.                                               |
| [5]    | DMADONEIEN     | <b>DMA Completion Interrupt</b><br>This bit enables the DMA completion interrupt<br>0 = DMA completion interrupt Disabled.<br>1 = DMA completion interrupt Enabled.                                        |
| [4]    | HISPDien       | <b>High-speed Settle</b><br>This bit enables the high-speed settle interrupt.<br>0 = High-speed settle interrupt Disabled.<br>1 = High-speed settle interrupt Enabled.                                     |
| [3]    | SUSPENDIE<br>N | <b>Suspend Request</b><br>This bit enables the Suspend interrupt.<br>0 = Suspend interrupt Disabled.<br>1 = Suspend interrupt Enabled.                                                                     |
| [2]    | RESUMEIEN      | <b>Resume</b><br>This bit enables the Resume interrupt.<br>0 = Resume interrupt Disabled.<br>1 = Resume interrupt Enabled.                                                                                 |

|     |               |                                                                                                                                           |
|-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | <b>RSTIEN</b> | <b>Reset Status</b><br>This bit enables the USB-Reset interrupt.<br>0 = USB-Reset interrupt Disabled.<br>1 = USB-Reset interrupt Enabled. |
| [0] | <b>SOFIEN</b> | <b>SOF Interrupt</b><br>This bit enables the SOF interrupt.<br>0 = SOF interrupt Disabled.<br>1 = SOF interrupt Enabled.                  |

USB Operational Register (HSUSBD\_OPER)

| Register    | Offset          | R/W | Description              |  |  |  | Reset Value |
|-------------|-----------------|-----|--------------------------|--|--|--|-------------|
| HSUSBD_OPER | HSUSBD_BA+0x018 | R/W | USB Operational Register |  |  |  | 0x0000_0002 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                     |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                           |
| [2]    | CURSPD      | <b>USB Current Speed</b><br>0 = The device has settled in Full Speed.<br>1 = The USB device controller has settled in High-speed.                                                                                                                                                                                   |
| [1]    | HISPDEN     | <b>USB High-speed</b><br>0 = The USB device controller to suppress the chirp-sequence during reset protocol, thereby allowing the USB device controller to settle in full-speed, even though it is connected to a USB2.0 Host.<br>1 = The USB device controller to initiate a chirp-sequence during reset protocol. |
| [0]    | RESUMEEN    | <b>Generate Resume</b><br>0 = No Resume sequence to be initiated to the host.<br>1 = A Resume sequence to be initiated to the host if device remote wakeup is enabled.<br>This bit is self-clearing.                                                                                                                |

USB Frame Count Register (HSUSBD\_FRAMECNT)

| Register        | Offset          | R/W | Description              | Reset Value |
|-----------------|-----------------|-----|--------------------------|-------------|
| HSUSBD_FRAMECNT | HSUSBD_BA+0x01C | R   | USB Frame Count Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                 |
| [13:3]  | FRAMECNT    | <b>Frame Counter</b><br>This field contains the frame count from the most recent start-of-frame packet.                   |
| [2:0]   | MFRAMECNT   | <b>Micro-frame Counter</b><br>This field contains the micro-frame number for the frame number in the frame counter field. |

USB Function Address Register (HSUSBD\_FADDR)

| Register     | Offset          | R/W | Description                   |  |  |  |  | Reset Value |
|--------------|-----------------|-----|-------------------------------|--|--|--|--|-------------|
| HSUSBD_FADDR | HSUSBD_BA+0x020 | R/W | USB Function Address Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                     |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                           |
| [6:0]  | FADDR       | <b>USB Function Address</b><br>This field contains the current USB address of the device. This field is cleared when a root port reset is detected. |

USB Test Mode Register (HSUSBD\_TEST)

| Register    | Offset          | R/W | Description            |  |  |  | Reset Value |
|-------------|-----------------|-----|------------------------|--|--|--|-------------|
| HSUSBD_TEST | HSUSBD_BA+0x024 | R/W | USB Test Mode 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 |    |    |    | TESTMODE |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                               |
| [2:0]  | TESTMODE    | <p><b>Test Mode Selection</b></p> <p>000 = Normal Operation.<br/>     001 = Test_J.<br/>     010 = Test_K.<br/>     011 = Test_SE0_NAK.<br/>     100 = Test_Packet.<br/>     101 = Test_Force_Enable.<br/>     110 = Reserved.<br/>     111 = Reserved.</p> <p><b>Note:</b> This field is cleared when root port reset is detected.</p> |

Control-ep Data Buffer (HSUSBD\_CEPDAT)

| Register      | Offset          | R/W | Description                  |  |  |  |  | Reset Value |
|---------------|-----------------|-----|------------------------------|--|--|--|--|-------------|
| HSUSBD_CEPDAT | HSUSBD_BA+0x028 | R/W | Control-Endpoint Data Buffer |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | DAT         | <b>Control-endpoint Data Buffer</b><br>Control endpoint data buffer for the buffer transaction (read or write).<br><b>Note:</b> Only word or byte access are supported. |

Control-endpoint Control Register (HSUSBD\_CEPCTL)

| Register      | Offset          | R/W | Description                       |  |  |  |  | Reset Value |
|---------------|-----------------|-----|-----------------------------------|--|--|--|--|-------------|
| HSUSBD_CEPCTL | HSUSBD_BA+0x02C | R/W | Control-Endpoint 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 |    |    |    | FLUSH | ZEROLEN | STALLEN | NAKCLR |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [3]    | FLUSH       | <b>CEP-flush Bit</b><br>0 = No the packet buffer and its corresponding HSUSBD_CEPDATCNT register to be cleared.<br>1 = The packet buffer and its corresponding HSUSBD_CEPDATCNT register to be cleared. This bit is self-cleaning.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [2]    | ZEROLEN     | <b>Zero Packet Length</b><br>This bit is valid for Auto Validation mode only.<br>0 = No zero length packet to the host during Data stage to an IN token.<br>1 = USB device controller can send a zero length packet to the host during Data stage to an IN token. This bit gets cleared once the zero length data packet is sent. So, the local CPU need not write again to clear this bit.                                                                                                                                                                                                                                                                                                                                                                             |
| [1]    | STALLEN     | <b>Stall Enable Bit</b><br>When this stall bit is set, the control endpoint sends a stall handshake in response to any in or out token thereafter. This is typically used for response to invalid/unsupported requests. When this bit is being set the NAK clear bit has to be cleared at the same time since the NAK clear bit has highest priority than STALL. It is automatically cleared on receipt of a next setup-token. So, the local CPU need not write again to clear this bit.<br>0 = No sends a stall handshake in response to any in or out token thereafter.<br>1 = The control endpoint sends a stall handshake in response to any in or out token thereafter.<br><b>Note:</b> Only when CPU writes data[1:0] is 2'b10 or 2'b00, this bit can be updated. |

|     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | NAKCLR | <p><b>No Acknowledge Control</b></p> <p>This bit plays a crucial role in any control transfer.</p> <p>0 = The bit is being cleared by the local CPU by writing zero, the USB device controller will be responding with NAKs for the subsequent status phase. This mechanism holds the host from moving to the next request, until the local CPU is also ready to process the next request.</p> <p>1 = This bit is set to one by the USB device controller, whenever a setup token is received. The local CPU can take its own time to finish off any house-keeping work based on the request and then clear this bit.</p> <p><b>Note:</b> Only when CPU writes data[1:0] is 2'b10 or 2'b00, this bit can be updated.</p> |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**Control Endpoint Interrupt Enable (HSUSBD\_CEPINTEN)**

| Register        | Offset          | R/W | Description                       |  |  |  | Reset Value |
|-----------------|-----------------|-----|-----------------------------------|--|--|--|-------------|
| HSUSBD_CEPINTEN | HSUSBD_BA+0x030 | R/W | Control-Endpoint Interrupt Enable |  |  |  | 0x0000_0000 |

|          |         |         |             |            |                |            |            |
|----------|---------|---------|-------------|------------|----------------|------------|------------|
| 31       | 30      | 29      | 28          | 27         | 26             | 25         | 24         |
| Reserved |         |         |             |            |                |            |            |
| 23       | 22      | 21      | 20          | 19         | 18             | 17         | 16         |
| Reserved |         |         |             |            |                |            |            |
| 15       | 14      | 13      | 12          | 11         | 10             | 9          | 8          |
| Reserved |         |         | BUFEMPTYIEN | BUFFULLIEN | STSDONEIE<br>N | ERRIEN     | STALLIEN   |
| 7        | 6       | 5       | 4           | 3          | 2              | 1          | 0          |
| NAKIEN   | RXPKIEN | TXPKIEN | PINGIEN     | INTKIEN    | OUTTKIEN       | SETUPPKIEN | SETUPTKIEN |

| Bits    | Description |                                                                                                                                                                                               |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:13] | Reserved    | Reserved.                                                                                                                                                                                     |
| [12]    | BUFEMPTYIEN | <b>Buffer Empty Interrupt</b><br>0 = The buffer empty interrupt in Control Endpoint Disabled.<br>1= The buffer empty interrupt in Control Endpoint Enabled.                                   |
| [11]    | BUFFULLIEN  | <b>Buffer Full Interrupt</b><br>0 = The buffer full interrupt in Control Endpoint Disabled.<br>1 = The buffer full interrupt in Control Endpoint Enabled.                                     |
| [10]    | STSDONEIEN  | <b>Status Completion Interrupt</b><br>0 = The Status Completion interrupt in Control Endpoint Disabled.<br>1 = The Status Completion interrupt in Control Endpoint Enabled.                   |
| [9]     | ERRIEN      | <b>USB Error Interrupt</b><br>0 = The USB Error interrupt in Control Endpoint Disabled.<br>1 = The USB Error interrupt in Control Endpoint Enabled.                                           |
| [8]     | STALLIEN    | <b>STALL Sent Interrupt</b><br>0 = The STALL sent interrupt in Control Endpoint Disabled.<br>1 = The STALL sent interrupt in Control Endpoint Enabled.                                        |
| [7]     | NAKIEN      | <b>NAK Sent Interrupt</b><br>0 = The NAK sent interrupt in Control Endpoint Disabled.<br>1 = The NAK sent interrupt in Control Endpoint Enabled.                                              |
| [6]     | RXPKIEN     | <b>Data Packet Received Interrupt</b><br>0 = The data received interrupt in Control Endpoint Disabled.<br>1 = The data received interrupt in Control Endpoint Enabled.                        |
| [5]     | TXPKIEN     | <b>Data Packet Transmitted Interrupt</b><br>0 = The data packet transmitted interrupt in Control Endpoint Disabled.<br>1 = The data packet transmitted interrupt in Control Endpoint Enabled. |

|     |                   |                                                                                                                                                                      |
|-----|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | <b>PINGIEN</b>    | <b>Ping Token Interrupt</b><br>0 = The ping token interrupt in Control Endpoint Disabled.<br>1 = The ping token interrupt Control Endpoint Enabled.                  |
| [3] | <b>INTKIEN</b>    | <b>In Token Interrupt</b><br>0 = The IN token interrupt in Control Endpoint Disabled.<br>1 = The IN token interrupt in Control Endpoint Enabled.                     |
| [2] | <b>OUTTKIEN</b>   | <b>Out Token Interrupt</b><br>0 = The OUT token interrupt in Control Endpoint Disabled.<br>1 = The OUT token interrupt in Control Endpoint Enabled.                  |
| [1] | <b>SETUPPKIEN</b> | <b>Setup Packet Interrupt</b><br>0 = The SETUP packet interrupt in Control Endpoint Disabled.<br>1 = The SETUP packet interrupt in Control Endpoint Enabled.         |
| [0] | <b>SETUPTKIEN</b> | <b>Setup Token Interrupt Enable Bit</b><br>0 = The SETUP token interrupt in Control Endpoint Disabled.<br>1 = The SETUP token interrupt in Control Endpoint Enabled. |

Control-endpoint Interrupt Status (HSUSBD\_CEPINTSTS)

| Register         | Offset          | R/W | Description                       |  |  |  | Reset Value |
|------------------|-----------------|-----|-----------------------------------|--|--|--|-------------|
| HSUSBD_CEPINTSTS | HSUSBD_BA+0x034 | R/W | Control-Endpoint Interrupt Status |  |  |  | 0x0000_1800 |

|          |        |        |            |           |           |           |           |
|----------|--------|--------|------------|-----------|-----------|-----------|-----------|
| 31       | 30     | 29     | 28         | 27        | 26        | 25        | 24        |
| Reserved |        |        |            |           |           |           |           |
| 23       | 22     | 21     | 20         | 19        | 18        | 17        | 16        |
| Reserved |        |        |            |           |           |           |           |
| 15       | 14     | 13     | 12         | 11        | 10        | 9         | 8         |
| Reserved |        |        | BUFEMPTYIF | BUFFULLIF | STSDONEIF | ERRIF     | STALLIF   |
| 7        | 6      | 5      | 4          | 3         | 2         | 1         | 0         |
| NAKIF    | RXPKIF | TXPKIF | PINGIF     | INTKIF    | OUTTKIF   | SETUPPKIF | SETUPTKIF |

| Bits    | Description |                                                                                                                                                                                                                      |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:13] | Reserved    | Reserved.                                                                                                                                                                                                            |
| [12]    | BUFEMPTYIF  | <b>Buffer Empty Interrupt</b><br>0 = The control-endpoint buffer is not empty.<br>1 = The control-endpoint buffer is empty.<br><b>Note:</b> Write 1 to clear this bit to 0.                                          |
| [11]    | BUFFULLIF   | <b>Buffer Full Interrupt</b><br>0 = The control-endpoint buffer is not full.<br>1 = The control-endpoint buffer is full.<br><b>Note:</b> Write 1 to clear this bit to 0.                                             |
| [10]    | STSDONEIF   | <b>Status Completion Interrupt</b><br>0 = Not a USB transaction has completed successfully.<br>1 = The status stage of a USB transaction has completed successfully.<br><b>Note:</b> Write 1 to clear this bit to 0. |
| [9]     | ERRIF       | <b>USB Error Interrupt</b><br>0 = No error had occurred during the transaction.<br>1 = An error had occurred during the transaction.<br><b>Note:</b> Write 1 to clear this bit to 0.                                 |
| [8]     | STALLIF     | <b>STALL Sent Interrupt</b><br>0 = Not a stall-token is sent in response to an IN/OUT token.<br>1 = A stall-token is sent in response to an IN/OUT token.<br><b>Note:</b> Write 1 to clear this bit to 0.            |
| [7]     | NAKIF       | <b>NAK Sent Interrupt</b><br>0 = Not a NAK-token is sent in response to an IN/OUT token.<br>1 = A NAK-token is sent in response to an IN/OUT token.<br><b>Note:</b> Write 1 to clear this bit to 0.                  |

|     |           |                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | RXPKIF    | <b>Data Packet Received Interrupt</b><br>0 = Not a data packet is successfully received from the host for an OUT-token and an ACK is sent to the host.<br>1 = A data packet is successfully received from the host for an OUT-token and an ACK is sent to the host.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                   |
| [5] | TXPKIF    | <b>Data Packet Transmitted Interrupt</b><br>0 = Not a data packet is successfully transmitted to the host in response to an IN-token and an ACK-token is received for the same.<br>1 = A data packet is successfully transmitted to the host in response to an IN-token and an ACK-token is received for the same.<br><b>Note:</b> Write 1 to clear this bit to 0.                                    |
| [4] | PINGIF    | <b>Ping Token Interrupt</b><br>0 = The control-endpoint does not receive a ping token from the host.<br>1 = The control-endpoint receives a ping token from the host.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                 |
| [3] | INTKIF    | <b>In Token Interrupt</b><br>0 = The control-endpoint does not receive an IN token from the host.<br>1 = The control-endpoint receives an IN token from the host.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                     |
| [2] | OUTTKIF   | <b>Out Token Interrupt</b><br>0 = The control-endpoint does not receive an OUT token from the host.<br>1 = The control-endpoint receives an OUT token from the host.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                  |
| [1] | SETUPPKIF | <b>Setup Packet Interrupt</b><br>This bit must be cleared (by writing 1) before the next setup packet can be received. If the bit is not cleared, then the successive setup packets will be overwritten in the setup packet buffer.<br>0 = Not a Setup packet has been received from the host.<br>1 = A Setup packet has been received from the host.<br><b>Note:</b> Write 1 to clear this bit to 0. |
| [0] | SETUPTKIF | <b>Setup Token Interrupt</b><br>0 = Not a Setup token is received.<br>1 = A Setup token is received. Writing 1 clears this status bit<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                                                 |

Control-endpoint In-transfer Data Count (HSUSBD\_CEPTXCNT)

| Register        | Offset          | R/W | Description                             |  |  |  |  | Reset Value |
|-----------------|-----------------|-----|-----------------------------------------|--|--|--|--|-------------|
| HSUSBD_CEPTXCNT | HSUSBD_BA+0x038 | R/W | Control-Endpoint In-transfer Data Count |  |  |  |  | 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  |
| TXCNT    |    |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [7:0]  | TXCNT       | <p><b>In-transfer Data Count</b></p> <p>There is no mode selection for the control endpoint (but it operates like manual mode).The local-CPU has to fill the control-endpoint buffer with the data to be sent for an in-token and to write the count of bytes in this register. When zero is written into this field, a zero length packet is sent to the host. When the count written in the register is more than the MPS, the data sent will be of only MPS.</p> |

Control-endpoint Out-transfer Data Count (HSUSBD\_CEPRXCNT)

| Register        | Offset          | R/W | Description                              |  |  |  | Reset Value |
|-----------------|-----------------|-----|------------------------------------------|--|--|--|-------------|
| HSUSBD_CEPRXCNT | HSUSBD_BA+0x03C | R   | Control-Endpoint Out-transfer Data Count |  |  |  | 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  |
| RXCNT    |    |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                               |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                     |
| [7:0]  | RXCNT       | <b>Out-transfer Data Count</b><br>The USB device controller maintains the count of the data received in case of an out transfer, during the control transfer. |

Control- Endpoint Data Count (HSUSBD\_CEPDATCNT)

| Register         | Offset          | R/W | Description                 |  |  |  | Reset Value |
|------------------|-----------------|-----|-----------------------------|--|--|--|-------------|
| HSUSBD_CEPDATCNT | HSUSBD_BA+0x040 | R   | Control-Endpoint data count |  |  |  | 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  |
| DATCNT   |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| DATCNT   |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                      |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                            |
| [15:0]  | DATCNT      | <b>Control-endpoint Data Count</b><br>The USB device controller maintains the count of the data of control-endpoint. |

**Setup1 & Setup0 Bytes (HSUSBD\_SETUP1\_0)**

| Register        | Offset          | R/W | Description           |  |  |  | Reset Value |
|-----------------|-----------------|-----|-----------------------|--|--|--|-------------|
| HSUSBD_SETUP1_0 | HSUSBD_BA+0x044 | R   | Setup1 & Setup0 bytes |  |  |  | 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  |
| SETUP1   |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SETUP0   |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [15:8]  | SETUP1      | <p><b>Setup Byte 1[15:8]</b></p> <p>This register provides byte 1 of the last setup packet received. For a Standard Device Request, the following bRequest Code information is returned.</p> <p>00000000 = Get Status.<br/>     00000001 = Clear Feature.<br/>     00000010 = Reserved.<br/>     00000011 = Set Feature.<br/>     00000100 = Reserved.<br/>     00000101 = Set Address.<br/>     00000110 = Get Descriptor.<br/>     00000111 = Set Descriptor.<br/>     00001000 = Get Configuration.<br/>     00001001 = Set Configuration.<br/>     00001010 = Get Interface.<br/>     00001011 = Set Interface.<br/>     00001100 = Sync Frame.</p> |

|       |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | <b>SETUP0</b> | <b>Setup Byte 0[7:0]</b><br>This register provides byte 0 of the last setup packet received. For a Standard Device Request, the following bmRequestType information is returned.<br>Bit 7(Direction):<br>0: Host to device<br>1: Device to host<br>Bit 6-5 (Type):<br>00: Standard<br>01: Class<br>10: Vendor<br>11: Reserved<br>Bit 4-0 (Recipient)<br>00000: Device<br>00001: Interface<br>00010: Endpoint<br>00011: Other<br>Others: Reserved |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**Setup3 & Setup2 Bytes (HSUSBD\_SETUP3\_2)**

| Register        | Offset          | R/W | Description           |  |  |  |  | Reset Value |
|-----------------|-----------------|-----|-----------------------|--|--|--|--|-------------|
| HSUSBD_SETUP3_2 | HSUSBD_BA+0x048 | R   | Setup3 & Setup2 Bytes |  |  |  |  | 0x0000_0000 |



| Bits    | Description     |                                                                                                                                                                                          |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                |
| [15:8]  | <b>SETUP3</b>   | <b>Setup Byte 3 [15:8]</b><br>This register provides byte 3 of the last setup packet received. For a Standard Device Request, the most significant byte of the wValue field is returned. |
| [7:0]   | <b>SETUP2</b>   | <b>Setup Byte 2 [7:0]</b><br>This register provides byte 2 of the last setup packet received. For a Standard Device Request, the least significant byte of the wValue field is returned. |

**Setup5 & Setup4 Bytes (HSUSBD\_SETUP5\_4)**

| Register        | Offset          | R/W | Description           |  |  |  | Reset Value |
|-----------------|-----------------|-----|-----------------------|--|--|--|-------------|
| HSUSBD_SETUP5_4 | HSUSBD_BA+0x04C | R   | Setup5 & Setup4 Bytes |  |  |  | 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  |
| SETUP5   |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SETUP4   |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                         |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                               |
| [15:8]  | SETUP5      | <b>Setup Byte 5[15:8]</b><br>This register provides byte 5 of the last setup packet received. For a Standard Device Request, the most significant byte of the wIndex field is returned. |
| [7:0]   | SETUP4      | <b>Setup Byte 4[7:0]</b><br>This register provides byte 4 of the last setup packet received. For a Standard Device Request, the least significant byte of the wIndex is returned.       |

**Setup7 & Setup6 Bytes (HSUSBD\_SETUP7\_6)**

| Register        | Offset          | R/W | Description           |  |  |  | Reset Value |
|-----------------|-----------------|-----|-----------------------|--|--|--|-------------|
| HSUSBD_SETUP7_6 | HSUSBD_BA+0x050 | R   | Setup7 & Setup6 Bytes |  |  |  | 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  |
| SETUP7   |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SETUP6   |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                |
| [15:8]  | SETUP7      | <b>Setup Byte 7[15:8]</b><br>This register provides byte 7 of the last setup packet received. For a Standard Device Request, the most significant byte of the wLength field is returned. |
| [7:0]   | SETUP6      | <b>Setup Byte 6[7:0]</b><br>This register provides byte 6 of the last setup packet received. For a Standard Device Request, the least significant byte of the wLength field is returned. |

Control Endpoint RAM Start Address Register (HSUSBD\_CEPBUFSTART)

| Register           | Offset          | R/W | Description                                 |  |  |  | Reset Value |
|--------------------|-----------------|-----|---------------------------------------------|--|--|--|-------------|
| HSUSBD_CEPBUFSTART | HSUSBD_BA+0x054 | R/W | Control Endpoint RAM Start Address Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                               |
| [11:0]  | SADDR       | <b>Control-endpoint Start Address</b><br>This is the start-address of the RAM space allocated for the control-endpoint. |

Control Endpoint RAM End Address Register (HSUSBD\_CEPBUFEND)

| Register         | Offset          | R/W | Description                               |  |  |  | Reset Value |
|------------------|-----------------|-----|-------------------------------------------|--|--|--|-------------|
| HSUSBD_CEPBUFEND | HSUSBD_BA+0x058 | R/W | Control Endpoint RAM End Address Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                           |
| [11:0]  | EADDR       | <b>Control-endpoint End Address</b><br>This is the end-address of the RAM space allocated for the control-endpoint. |

DMA Control Status Register (HSUSBD\_DMACTL)

| Register      | Offset          | R/W | Description                 |  |  |  |  | Reset Value |
|---------------|-----------------|-----|-----------------------------|--|--|--|--|-------------|
| HSUSBD_DMACTL | HSUSBD_BA+0x05C | R/W | DMA Control 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  |  |
| DMARST   | SGEN | DMAEN | DMARD | EPNUM |    |    |    |  |

| Bits   | Description |                                                                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                   |
| [8]    | SVINEP      | <b>Serve IN Endpoint</b><br>This bit is used to specify DMA serving endpoint-IN endpoint or OUT endpoint.<br>0 = DMA serves OUT endpoint.<br>1 = DMA serves IN endpoint.                                                                                                    |
| [7]    | DMARST      | <b>Reset DMA State Machine</b><br>0 = No reset the DMA state machine.<br>1 = Reset the DMA state machine.                                                                                                                                                                   |
| [6]    | SGEN        | <b>Scatter Gather Function Enable Bit</b><br>0 = Scatter gather function Disabled.<br>1 = Scatter gather function Enabled.                                                                                                                                                  |
| [5]    | DMAEN       | <b>DMA Enable Bit</b><br>0 = DMA function Disabled.<br>1 = DMA function Enabled.                                                                                                                                                                                            |
| [4]    | DMARD       | <b>DMA Operation</b><br>0 = The operation is a DMA write (read from USB buffer). DMA will check endpoint data available count (HSUSBD_EPxDATCNT) according to EPNM setting before to perform DMA write operation.<br>1 = The operation is a DMA read (write to USB buffer). |
| [3:0]  | EPNUM       | <b>DMA Endpoint Address Bits</b><br>Used to define the Endpoint Address                                                                                                                                                                                                     |

DMA Count Register (HSUSBD\_DMACNT)

| Register      | Offset          | R/W | Description        |  |  |  | Reset Value |
|---------------|-----------------|-----|--------------------|--|--|--|-------------|
| HSUSBD_DMACNT | HSUSBD_BA+0x060 | R/W | DMA Count Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                            |
|---------|-------------|------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                  |
| [19:0]  | DMACNT      | DMA Transfer Count<br>The transfer count of the DMA operation to be performed is written to this register. |

Endpoint A~L Data Register (HSUSBD\_EPADAT~ HSUSBD\_EPLDAT)

| Register      | Offset          | R/W | Description              | Reset Value |
|---------------|-----------------|-----|--------------------------|-------------|
| HSUSBD_EPADAT | HSUSBD_BA+0x064 | R/W | Endpoint A Data Register | 0x0000_0000 |
| HSUSBD_EPBDAT | HSUSBD_BA+0x08C | R/W | Endpoint B Data Register | 0x0000_0000 |
| HSUSBD_EPCDAT | HSUSBD_BA+0x0B4 | R/W | Endpoint C Data Register | 0x0000_0000 |
| HSUSBD_EPDDAT | HSUSBD_BA+0x0DC | R/W | Endpoint D Data Register | 0x0000_0000 |
| HSUSBD_EPEDAT | HSUSBD_BA+0x104 | R/W | Endpoint E Data Register | 0x0000_0000 |
| HSUSBD_EPFDAT | HSUSBD_BA+0x12C | R/W | Endpoint F Data Register | 0x0000_0000 |
| HSUSBD_EPGDAT | HSUSBD_BA+0x154 | R/W | Endpoint G Data Register | 0x0000_0000 |
| HSUSBD_EPHDAT | HSUSBD_BA+0x17C | R/W | Endpoint H Data Register | 0x0000_0000 |
| HSUSBD_EPIDAT | HSUSBD_BA+0x1A4 | R/W | Endpoint I Data Register | 0x0000_0000 |
| HSUSBD_EPJDAT | HSUSBD_BA+0x1CC | R/W | Endpoint J Data Register | 0x0000_0000 |
| HSUSBD_EPKDAT | HSUSBD_BA+0x1F4 | R/W | Endpoint K Data Register | 0x0000_0000 |
| HSUSBD_EPLDAT | HSUSBD_BA+0x21C | R/W | Endpoint L Data Register | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | EPDAT       | <b>Endpoint A~L Data Register</b><br>Endpoint A~L data buffer for the buffer transaction (read or write).<br><b>Note:</b> Only word or byte access are supported. |

Endpoint A~L Interrupt Status Register (HSUSBD\_EPAINTSTS~ HSUSBD\_EPLINTSTS)

| Register         | Offset          | R/W | Description                          | Reset Value |
|------------------|-----------------|-----|--------------------------------------|-------------|
| HSUSBD_EPAINTSTS | HSUSBD_BA+0x068 | R/W | Endpoint A Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPBINTSTS | HSUSBD_BA+0x090 | R/W | Endpoint B Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPCINTSTS | HSUSBD_BA+0x0B8 | R/W | Endpoint C Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPDINTSTS | HSUSBD_BA+0x0E0 | R/W | Endpoint D Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPEINTSTS | HSUSBD_BA+0x108 | R/W | Endpoint E Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPFINTSTS | HSUSBD_BA+0x130 | R/W | Endpoint F Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPGINTSTS | HSUSBD_BA+0x158 | R/W | Endpoint G Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPHINTSTS | HSUSBD_BA+0x180 | R/W | Endpoint H Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPIINTSTS | HSUSBD_BA+0x1A8 | R/W | Endpoint I Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPJINTSTS | HSUSBD_BA+0x1D0 | R/W | Endpoint J Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPKINTSTS | HSUSBD_BA+0x1F8 | R/W | Endpoint K Interrupt Status Register | 0x0000_0003 |
| HSUSBD_EPLINTSTS | HSUSBD_BA+0x220 | R/W | Endpoint L Interrupt Status Register | 0x0000_0003 |

|          |        |         |           |        |           |             |           |
|----------|--------|---------|-----------|--------|-----------|-------------|-----------|
| 31       | 30     | 29      | 28        | 27     | 26        | 25          | 24        |
| Reserved |        |         |           |        |           |             |           |
| 23       | 22     | 21      | 20        | 19     | 18        | 17          | 16        |
| Reserved |        |         |           |        |           |             |           |
| 15       | 14     | 13      | 12        | 11     | 10        | 9           | 8         |
| Reserved |        |         | SHORTRXIF | ERRIF  | NYETIF    | STALLIF     | NAKIF     |
| 7        | 6      | 5       | 4         | 3      | 2         | 1           | 0         |
| PINGIF   | INTKIF | OUTTKIF | RXPKIF    | TXPKIF | SHORTTXIF | BUFEEMPTYIF | BUFFULLIF |

| Bits    | Description |                                                                                                                                                                                                          |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:13] | Reserved    | Reserved.                                                                                                                                                                                                |
| [12]    | SHORTRXIF   | <b>Bulk Out Short Packet Received</b><br>0 = No bulk out short packet is received.<br>1 = Received bulk out short packet (including zero length packet).<br><b>Note:</b> Write 1 to clear this bit to 0. |

|      |                |                                                                                                                                                                                                                                                                                                                                       |
|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11] | <b>ERRIF</b>   | <b>ERR Sent</b><br>0 = No any error in the transaction.<br>1 = There occurs any error in the transaction.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                             |
| [10] | <b>NYETIF</b>  | <b>NYET Sent</b><br>0 = The space available in the RAM is sufficient to accommodate the next on coming data packet.<br>1 = The space available in the RAM is not sufficient to accommodate the next on coming data packet.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                            |
| [9]  | <b>STALLIF</b> | <b>USB STALL Sent</b><br>0 = The last USB packet could be accepted or provided because the endpoint was stalled, and was acknowledged with a STALL.<br>1 = The last USB packet could not be accepted or provided because the endpoint was stalled, and was acknowledged with a STALL.<br><b>Note:</b> Write 1 to clear this bit to 0. |
| [8]  | <b>NAKIF</b>   | <b>USB NAK Sent</b><br>0 = The last USB IN packet could be provided, and was acknowledged with an ACK.<br>1 = The last USB IN packet could not be provided, and was acknowledged with a NAK.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                          |
| [7]  | <b>PINGIF</b>  | <b>PING Token Interrupt</b><br>0 = A Data PING token has not been received from the host.<br>1 = A Data PING token has been received from the host.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                   |
| [6]  | <b>INTKIF</b>  | <b>Data IN Token Interrupt</b><br>0 = Not Data IN token has been received from the host.<br>1 = A Data IN token has been received from the host.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                      |
| [5]  | <b>OUTTKIF</b> | <b>Data OUT Token Interrupt</b><br>0 = A Data OUT token has not been received from the host.<br>1 = A Data OUT token has been received from the host. This bit also set by PING token (in high-speed only).<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                           |
| [4]  | <b>RXPKIF</b>  | <b>Data Packet Received Interrupt</b><br>0 = No data packet is received from the host by the endpoint.<br>1 = A data packet is received from the host by the endpoint.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                |
| [3]  | <b>TXPKIF</b>  | <b>Data Packet Transmitted Interrupt</b><br>0 = Not a data packet is transmitted from the endpoint to the host.<br>1 = A data packet is transmitted from the endpoint to the host.<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                    |

|     |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | <b>SHORTTXIF</b>  | <b>Short Packet Transferred Interrupt</b><br>0 = The length of the last packet was not less than the Maximum Packet Size (EPMPS).<br>1 = The length of the last packet was less than the Maximum Packet Size (EPMPS).<br><b>Note:</b> Write 1 to clear this bit to 0.                                                                                                                                                                                              |
| [1] | <b>BUFEMPTYIF</b> | <b>Buffer Empty</b><br>For an IN endpoint, a buffer is available to the local side for writing up to FIFO full of bytes.<br>0 = The endpoint buffer is not empty.<br>1 = The endpoint buffer is empty.<br>For an OUT endpoint:<br>0 = The currently selected buffer has not a count of 0.<br>1 = The currently selected buffer has a count of 0, or no buffer is available on the local side (nothing to read).<br><b>Note:</b> This bit is read-only.             |
| [0] | <b>BUFFULLIF</b>  | <b>Buffer Full</b><br>For an IN endpoint, the currently selected buffer is full, or no buffer is available to the local side for writing (no space to write). For an OUT endpoint, there is a buffer available on the local side, and there are FIFO full of bytes available to be read (entire packet is available for reading).<br>0 = The endpoint packet buffer is not full.<br>1 = The endpoint packet buffer is full.<br><b>Note:</b> This bit is read-only. |

Endpoint A~L Interrupt Enable Control Register (HSUSBD\_EPAINTEN~ HSUSBD\_EPLINTEN)

| Register         | Offset          | R/W | Description                          | Reset Value |
|------------------|-----------------|-----|--------------------------------------|-------------|
| HSUSBD_EPAINTEN  | HSUSBD_BA+0x06C | R/W | Endpoint A Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPBINTE N | HSUSBD_BA+0x094 | R/W | Endpoint B Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPCINTE N | HSUSBD_BA+0x0BC | R/W | Endpoint C Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPDINTE N | HSUSBD_BA+0x0E4 | R/W | Endpoint D Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPEINTE N | HSUSBD_BA+0x10C | R/W | Endpoint E Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPFINTE N | HSUSBD_BA+0x134 | R/W | Endpoint F Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPGINTE N | HSUSBD_BA+0x15C | R/W | Endpoint G Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPHINTE N | HSUSBD_BA+0x184 | R/W | Endpoint H Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPIINTE N | HSUSBD_BA+0x1AC | R/W | Endpoint I Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPJINTE N | HSUSBD_BA+0x1D4 | R/W | Endpoint J Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPKINTE N | HSUSBD_BA+0x1FC | R/W | Endpoint K Interrupt Enable Register | 0x0000_0000 |
| HSUSBD_EPLINTE N | HSUSBD_BA+0x224 | R/W | Endpoint L 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 |         |          | SHORTRXIEN | ERRIEN  | NYETIEN    | STALLIEN    | NAKIEN     |
| 7        | 6       | 5        | 4          | 3       | 2          | 1           | 0          |
| PINGIEN  | INTKIEN | OUTTKIEN | RXPKIEN    | TXPKIEN | SHORTTXIEN | BUFEMPTYIEN | BUFFULLIEN |

| Bits    | Description |           |  |  |  |  |  |
|---------|-------------|-----------|--|--|--|--|--|
| [31:13] | Reserved    | Reserved. |  |  |  |  |  |

|      |                   |                                                                                                                                                                                                                                                                                                                |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [12] | <b>SHORTRXIEN</b> | <b>Bulk Out Short Packet Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set whenever bulk out short packet occurs on the bus for this endpoint.<br>0 = Bulk out interrupt Disabled.<br>1 = Bulk out interrupt Enabled.                                                         |
| [11] | <b>ERRIEN</b>     | <b>ERR Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set whenever ERR condition occurs on the bus for this endpoint.<br>0 = Error event interrupt Disabled.<br>1 = Error event interrupt Enabled.                                                                             |
| [10] | <b>NYETIEN</b>    | <b>NYET Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set whenever NYET condition occurs on the bus for this endpoint.<br>0 = NYET condition interrupt Disabled.<br>1 = NYET condition interrupt Enabled.                                                                     |
| [9]  | <b>STALLIEN</b>   | <b>USB STALL Sent Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a stall token is sent to the host.<br>0 = STALL token interrupt Disabled.<br>1 = STALL token interrupt Enabled.                                                                                      |
| [8]  | <b>NAKIEN</b>     | <b>USB NAK Sent Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a NAK token is sent to the host.<br>0 = NAK token interrupt Disabled.<br>1 = NAK token interrupt Enabled.                                                                                              |
| [7]  | <b>PINGIEN</b>    | <b>PING Token Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a PING token has been received from the host.<br>0 = PING token interrupt Disabled.<br>1 = PING token interrupt Enabled.                                                                                 |
| [6]  | <b>INTKien</b>    | <b>Data IN Token Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a Data IN token has been received from the host.<br>0 = Data IN token interrupt Disabled.<br>1 = Data IN token interrupt Enabled.                                                                     |
| [5]  | <b>OUTTKIEN</b>   | <b>Data OUT Token Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a Data OUT token has been received from the host.<br>0 = Data OUT token interrupt Disabled.<br>1 = Data OUT token interrupt Enabled.                                                                 |
| [4]  | <b>RXPKIEN</b>    | <b>Data Packet Received Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a data packet has been transmitted to the host.<br>0 = Data packet has been transmitted to the host interrupt Disabled.<br>1 = Data packet has been transmitted to the host interrupt Enabled. |

|     |                    |                                                                                                                                                                                                                                                                                                                |
|-----|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3] | <b>TXPKIEN</b>     | <b>Data Packet Transmitted Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a data packet has been received from the host.<br>0 = Data packet has been received from the host interrupt Disabled.<br>1 = Data packet has been received from the host interrupt Enabled. |
| [2] | <b>SHORTTXIEN</b>  | <b>Short Packet Transferred Interrupt Enable Bit</b><br>When set, this bit enables a local interrupt to be set when a short data packet has been transferred to/from the host.<br>0 = Short data packet interrupt Disabled.<br>1 = Short data packet interrupt Enabled.                                        |
| [1] | <b>BUFEMPTYIEN</b> | <b>Buffer Empty Interrupt</b><br>When set, this bit enables a local interrupt to be set when a buffer empty condition is detected on the bus.<br>0 = Buffer empty interrupt Disabled.<br>1 = Buffer empty interrupt Enabled.                                                                                   |
| [0] | <b>BUFFULLIEN</b>  | <b>Buffer Full Interrupt</b><br>When set, this bit enables a local interrupt to be set when a buffer full condition is detected on the bus.<br>0 = Buffer full interrupt Disabled.<br>1 = Buffer full interrupt Enabled.                                                                                       |

Endpoint A~L Data Available Count Register (HSUSBD\_EPADATCNT~ HSUSBD\_EPLDATCNT)

| Register         | Offset          | R/W | Description                              | Reset Value |
|------------------|-----------------|-----|------------------------------------------|-------------|
| HSUSBD_EPADATCNT | HSUSBD_BA+0x070 | R   | Endpoint A Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPBDATCNT | HSUSBD_BA+0x098 | R   | Endpoint B Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPCDATCNT | HSUSBD_BA+0x0C0 | R   | Endpoint C Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPDDATCNT | HSUSBD_BA+0x0E8 | R   | Endpoint D Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPEDATCNT | HSUSBD_BA+0x110 | R   | Endpoint E Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPFDATCNT | HSUSBD_BA+0x138 | R   | Endpoint F Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPGDATCNT | HSUSBD_BA+0x160 | R   | Endpoint G Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPHDATCNT | HSUSBD_BA+0x188 | R   | Endpoint H Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPIDATCNT | HSUSBD_BA+0x1B0 | R   | Endpoint I Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPJDATCNT | HSUSBD_BA+0x1D8 | R   | Endpoint J Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPKDATCNT | HSUSBD_BA+0x200 | R   | Endpoint K Data Available Count Register | 0x0000_0000 |
| HSUSBD_EPLDATCNT | HSUSBD_BA+0x228 | R   | Endpoint L Data Available Count Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                        |
|---------|-------------|----------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                              |
| [30:16] | DMALOOP     | This register is the remaining DMA loop to complete. Each loop means 32-byte transfer. |

|        |        |                                                                                                                                                                                                                                                                                                          |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0] | DATCNT | <b>Data Count</b><br>For an IN endpoint (EPDIR(HSUSBD_EPxCFG[3] is high.), this register returns the number of valid bytes in the IN endpoint packet buffer.<br>For an OUT endpoint (EPDIR(HSUSBD_EPxCFG[3] is low.), this register returns the number of received valid bytes in the Host OUT transfer. |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Endpoint A~L Response Control Register (HSUSBD\_EPARSPCTL~ HSUSBD\_EPLRSPCTL)

| Register           | Offset          | R/W | Description                          | Reset Value |
|--------------------|-----------------|-----|--------------------------------------|-------------|
| HSUSBD_EPARSPCTL   | HSUSBD_BA+0x074 | R/W | Endpoint A Response Control Register | 0x0000_0000 |
| HSUSBD_EPBRSPCTL   | HSUSBD_BA+0x09C | R/W | Endpoint B Response Control Register | 0x0000_0000 |
| HSUSBD_EPCRSPCTL   | HSUSBD_BA+0x0C4 | R/W | Endpoint C Response Control Register | 0x0000_0000 |
| HSUSBD_EPDRSPCTL   | HSUSBD_BA+0x0EC | R/W | Endpoint D Response Control Register | 0x0000_0000 |
| HSUSBD_EPERSPCTL   | HSUSBD_BA+0x114 | R/W | Endpoint E Response Control Register | 0x0000_0000 |
| HSUSBD_EPFRSPCTL   | HSUSBD_BA+0x13C | R/W | Endpoint F Response Control Register | 0x0000_0000 |
| HSUSBD_EPGRSPCTL   | HSUSBD_BA+0x164 | R/W | Endpoint G Response Control Register | 0x0000_0000 |
| HSUSBD_EPHRSPCTL   | HSUSBD_BA+0x18C | R/W | Endpoint H Response Control Register | 0x0000_0000 |
| HSUSBD_EPIRSPCTL   | HSUSBD_BA+0x1B4 | R/W | Endpoint I Response Control Register | 0x0000_0000 |
| HSUSBD_EPJRSRSPCTL | HSUSBD_BA+0x1DC | R/W | Endpoint J Response Control Register | 0x0000_0000 |
| HSUSBD_EPKRSPCTL   | HSUSBD_BA+0x204 | R/W | Endpoint K Response Control Register | 0x0000_0000 |
| HSUSBD_EPLRSPCTL   | HSUSBD_BA+0x22C | R/W | Endpoint L Response 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     |
| DISBUF   | SHORTTXEN | ZEROLEN | HALT | TOGGLE | MODE |    | FLUSH |

| Bits   | Description |           |  |
|--------|-------------|-----------|--|
| [31:8] | Reserved    | Reserved. |  |

|       |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | <b>DISBUF</b>    | <b>Buffer Disable Bit</b><br>This bit is used to receive unknown size OUT short packet. The received packet size is reference HSUSBD_EPxDATCNT register.<br>0 = Buffer Not Disabled when Bulk-OUT short packet is received.<br>1 = Buffer Disabled when Bulk-OUT short packet is received.                                                                                                                                                                                                                                   |
| [6]   | <b>SHORTTXEN</b> | <b>Short Packet Transfer Enable</b><br>This bit is applicable only in case of Auto-Validate Method. This bit is set to validate any remaining data in the buffer which is not equal to the MPS of the endpoint, and happens to be the last transfer. This bit gets cleared once the data packet is sent.<br>0 = Not validate any remaining data in the buffer which is not equal to the MPS of the endpoint.<br>1 = Validate any remaining data in the buffer which is not equal to the MPS of the endpoint.                 |
| [5]   | <b>ZEROLEN</b>   | <b>Zero Length</b><br>This bit is used to send a zero-length packet response to an IN-token. When this bit is set, a zero packet is sent to the host on reception of an IN-token. This bit gets cleared once the zero length data packet is sent.<br>0 = A zero packet is not sent to the host on reception of an IN-token.<br>1 = A zero packet is sent to the host on reception of an IN-token.                                                                                                                            |
| [4]   | <b>HALT</b>      | <b>Endpoint Halt</b><br>This bit is used to send a STALL handshake as response to the token from the host. When an Endpoint Set Feature (ep_halt) is detected by the local CPU, it must write a '1' to this bit.<br>0 = Not send a STALL handshake as response to the token from the host.<br>1 = Send a STALL handshake as response to the token from the host.                                                                                                                                                             |
| [3]   | <b>TOGGLE</b>    | <b>Endpoint Toggle</b><br>This bit is used to clear the endpoint data toggle bit. Reading this bit returns the current state of the endpoint data toggle bit.<br>The local CPU may use this bit to initialize the end-point's toggle in case of reception of a Set Interface request or a Clear Feature (ep_halt) request from the host. Only when toggle bit is "1", this bit can be written into the inverted write data bit[3].<br>0 = Not clear the endpoint data toggle bit.<br>1 = Clear the endpoint data toggle bit. |
| [2:1] | <b>MODE</b>      | <b>Mode Control</b><br>The two bits decide the operation mode of the in-endpoint.<br>00 = Auto-Validate Mode.<br>01 = Manual-Validate Mode.<br>10 = Fly Mode.<br>11 = Reserved.<br>These bits are not valid for an out-endpoint. The auto validate mode will be activated when the reserved mode is selected.                                                                                                                                                                                                                |
| [0]   | <b>FLUSH</b>     | <b>Buffer Flush</b><br>Writing 1 to this bit causes the packet buffer to be flushed and the corresponding EP_AVAIL register to be cleared. This bit is self-clearing. This bit should always be written after an configuration event.<br>0 = The packet buffer is not flushed.<br>1 = The packet buffer is flushed by user.                                                                                                                                                                                                  |

Endpoint A~L Maximum Packet Size Register (HSUSBD\_EPAMPS~ HSUSBD\_EPLMPS)

| Register      | Offset          | R/W | Description                             | Reset Value |
|---------------|-----------------|-----|-----------------------------------------|-------------|
| HSUSBD_EPAMPS | HSUSBD_BA+0x078 | R/W | Endpoint A Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPBMPS | HSUSBD_BA+0x0A0 | R/W | Endpoint B Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPCMPS | HSUSBD_BA+0x0C8 | R/W | Endpoint C Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPDMPS | HSUSBD_BA+0x0F0 | R/W | Endpoint D Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPEMPS | HSUSBD_BA+0x118 | R/W | Endpoint E Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPFMPS | HSUSBD_BA+0x140 | R/W | Endpoint F Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPGMPS | HSUSBD_BA+0x168 | R/W | Endpoint G Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPHMPS | HSUSBD_BA+0x190 | R/W | Endpoint H Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPIMPS | HSUSBD_BA+0x1B8 | R/W | Endpoint I Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPJMPS | HSUSBD_BA+0x1E0 | R/W | Endpoint J Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPKMPS | HSUSBD_BA+0x208 | R/W | Endpoint K Maximum Packet Size Register | 0x0000_0000 |
| HSUSBD_EPLMPS | HSUSBD_BA+0x230 | R/W | Endpoint L Maximum Packet Size 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 |    |    |    |    | EPMPS |    |    |
| 7        | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| EPMPS    |    |    |    |    |       |    |    |

| Bits    | Description |                                                                                                |
|---------|-------------|------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                      |
| [10:0]  | EPMPS       | Endpoint Maximum Packet Size<br>This field determines the Maximum Packet Size of the Endpoint. |

Endpoint A~L Transfer Count Register (HSUSBD\_EPATXCNT~ HSUSBD\_EPLTXCNT)

| Register        | Offset           | R/W | Description                        | Reset Value |
|-----------------|------------------|-----|------------------------------------|-------------|
| HSUSBD_EPATXCNT | HSUSBD_BA+0x07C  | R/W | Endpoint A Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPBTXCN  | HSUSBD_BA+0x0A4  | R/W | Endpoint B Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPCTXCN  | HSUSBD_BA+0x0C0C | R/W | Endpoint C Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPDTXCN  | HSUSBD_BA+0x0F4  | R/W | Endpoint D Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPETXCN  | HSUSBD_BA+0x11C  | R/W | Endpoint E Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPFXTXCN | HSUSBD_BA+0x144  | R/W | Endpoint F Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPGTXCN  | HSUSBD_BA+0x16C  | R/W | Endpoint G Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPHTXCN  | HSUSBD_BA+0x194  | R/W | Endpoint H Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPITXCN  | HSUSBD_BA+0x1B0C | R/W | Endpoint I Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPJTXCN  | HSUSBD_BA+0x1E4  | R/W | Endpoint J Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPKTXCN  | HSUSBD_BA+0x20C  | R/W | Endpoint K Transfer Count Register | 0x0000_0000 |
| HSUSBD_EPLTXCN  | HSUSBD_BA+0x234  | R/W | Endpoint L Transfer Count Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                 |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                       |
| [10:0]  | TXCNT       | <b>Endpoint Transfer Count</b><br>For IN endpoints, this field determines the total number of bytes to be sent to the host in case of manual validation method.<br>For OUT endpoints, this field has no effect. |

**Endpoint A~L Configuration Register (HSUSBD\_EPACFG~ HSUSBD\_EPLCFG)**

| Register          | Offset          | R/W | Description                       | Reset Value |
|-------------------|-----------------|-----|-----------------------------------|-------------|
| HSUSBD_EPA<br>CFG | HSUSBD_BA+0x080 | R/W | Endpoint A Configuration Register | 0x0000_0012 |
| HSUSBD_EPB<br>CFG | HSUSBD_BA+0x0A8 | R/W | Endpoint B Configuration Register | 0x0000_0022 |
| HSUSBD_EPC<br>CFG | HSUSBD_BA+0x0D0 | R/W | Endpoint C Configuration Register | 0x0000_0032 |
| HSUSBD_EPD<br>CFG | HSUSBD_BA+0x0F8 | R/W | Endpoint D Configuration Register | 0x0000_0042 |
| HSUSBD_EPE<br>CFG | HSUSBD_BA+0x120 | R/W | Endpoint E Configuration Register | 0x0000_0052 |
| HSUSBD_EPF<br>CFG | HSUSBD_BA+0x148 | R/W | Endpoint F Configuration Register | 0x0000_0062 |
| HSUSBD_EPG<br>CFG | HSUSBD_BA+0x170 | R/W | Endpoint G Configuration Register | 0x0000_0072 |
| HSUSBD_EPH<br>CFG | HSUSBD_BA+0x198 | R/W | Endpoint H Configuration Register | 0x0000_0082 |
| HSUSBD_EPIC<br>FG | HSUSBD_BA+0x1C0 | R/W | Endpoint I Configuration Register | 0x0000_0092 |
| HSUSBD_EPJ<br>CFG | HSUSBD_BA+0x1E8 | R/W | Endpoint J Configuration Register | 0x0000_00A2 |
| HSUSBD_EPK<br>CFG | HSUSBD_BA+0x210 | R/W | Endpoint K Configuration Register | 0x0000_00B2 |
| HSUSBD_EPL<br>CFG | HSUSBD_BA+0x238 | R/W | Endpoint L Configuration Register | 0x0000_00C2 |

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

| Bits   | Description |                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                               |
| [7:4]  | EPNUM       | <b>Endpoint Number</b><br>This field selects the number of the endpoint. Valid numbers 1 to 15.<br><b>Note:</b> Do not support two endpoints have same endpoint number. |

|       |               |                                                                                                                                                                                                       |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]   | <b>EPDIR</b>  | <b>Endpoint Direction</b><br>0 = out-endpoint (Host OUT to Device).<br>1 = in-endpoint (Host IN to Device).<br><b>Note:</b> A maximum of one OUT and IN endpoint is allowed for each endpoint number. |
| [2:1] | <b>EPTYPE</b> | <b>Endpoint Type</b><br>This field selects the type of this endpoint. Endpoint 0 is forced to a Control type.<br>00 = Reserved.<br>01 = Bulk.<br>10 = Interrupt.<br>11 = Isochronous.                 |
| [0]   | <b>EPEN</b>   | <b>Endpoint Valid</b><br>When set, this bit enables this endpoint. This bit has no effect on Endpoint 0, which is always enabled.<br>0 = The endpoint Disabled.<br>1 = The endpoint Enabled.          |

| Endpoint | A~L | RAM | Start | Address | Register | (HSUSBD_EPLBUFSTART~HSUSBD_EPLBUFSTART) |
|----------|-----|-----|-------|---------|----------|-----------------------------------------|
|----------|-----|-----|-------|---------|----------|-----------------------------------------|

| Register               | Offset              | R/W | Description                           |  |  | Reset Value |
|------------------------|---------------------|-----|---------------------------------------|--|--|-------------|
| HSUSBD_EPABUFSTA<br>RT | HSUSBD_BA+0x084     | R/W | Endpoint A RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPBBUFSTA<br>RT | HSUSBD_BA+0x0A<br>C | R/W | Endpoint B RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPCBUFSTA<br>RT | HSUSBD_BA+0x0D<br>4 | R/W | Endpoint C RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPDBUFSTA<br>RT | HSUSBD_BA+0x0F<br>C | R/W | Endpoint D RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPEBUFSTA<br>RT | HSUSBD_BA+0x124     | R/W | Endpoint E RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPFBUFSTA<br>RT | HSUSBD_BA+0x14<br>C | R/W | Endpoint F RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPGBUFSTA<br>RT | HSUSBD_BA+0x174     | R/W | Endpoint G RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPHBUFSTA<br>RT | HSUSBD_BA+0x19<br>C | R/W | Endpoint H RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPIBUFSTAR<br>T | HSUSBD_BA+0x1C<br>4 | R/W | Endpoint I RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPJBUFSTA<br>RT | HSUSBD_BA+0x1E<br>C | R/W | Endpoint J RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPKBUFSTA<br>RT | HSUSBD_BA+0x214     | R/W | Endpoint K RAM Start Address Register |  |  | 0x0000_0000 |
| HSUSBD_EPLBUFSTA<br>RT | HSUSBD_BA+0x23<br>C | R/W | Endpoint L RAM Start Address Register |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                            |
| [11:0]  | SADDR       | Endpoint Start Address<br>This is the start-address of the RAM space allocated for the endpoint A~L. |

Endpoint A~L RAM End Address Register (HSUSBD\_EPABUFEND~ HSUSBD\_EPLBUFEND)

| Register         | Offset          | R/W | Description                         | Reset Value |
|------------------|-----------------|-----|-------------------------------------|-------------|
| HSUSBD_EPABUFEND | HSUSBD_BA+0x088 | R/W | Endpoint A RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPBBUFEND | HSUSBD_BA+0x0B0 | R/W | Endpoint B RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPCBUFEND | HSUSBD_BA+0x0D8 | R/W | Endpoint C RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPDBUFEND | HSUSBD_BA+0x100 | R/W | Endpoint D RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPEBUFEND | HSUSBD_BA+0x128 | R/W | Endpoint E RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPFBUFEND | HSUSBD_BA+0x150 | R/W | Endpoint F RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPGBUFEND | HSUSBD_BA+0x178 | R/W | Endpoint G RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPHBUFEND | HSUSBD_BA+0x1A0 | R/W | Endpoint H RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPIBUFEND | HSUSBD_BA+0x1C8 | R/W | Endpoint I RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPJBUFEND | HSUSBD_BA+0x1F0 | R/W | Endpoint J RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPKBUFEND | HSUSBD_BA+0x218 | R/W | Endpoint K RAM End Address Register | 0x0000_0000 |
| HSUSBD_EPLBUFEND | HSUSBD_BA+0x240 | R/W | Endpoint L RAM End Address Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                  |
|---------|-------------|--------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                        |
| [11:0]  | EADDR       | Endpoint End Address<br>This is the end-address of the RAM space allocated for the endpoint A~L. |

AHB Address Register (HSUSBD DMAADDR)

| Register       | Offset          | R/W | Description              | Reset Value |
|----------------|-----------------|-----|--------------------------|-------------|
| HSUSBD_DMAADDR | HSUSBD_BA+0x700 | R/W | AHB DMA Address Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                               |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | DMAADDR     | DMAADDR<br>The register specifies the address from which the DMA has to read / write. The address must WORD (32-bit) aligned. |

USB PHY Control Register (HSUSBD\_PHYCTL)

| Register      | Offset          | R/W | Description              |  |  |  | Reset Value |
|---------------|-----------------|-----|--------------------------|--|--|--|-------------|
| HSUSBD_PHYCTL | HSUSBD_BA+0x704 | R/W | USB PHY Control Register |  |  |  | 0x0000_0420 |

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

| Bits    | Description     |                                                                                                      |
|---------|-----------------|------------------------------------------------------------------------------------------------------|
| [31]    | <b>VBUSDET</b>  | <b>VBUS Status</b><br>0 = The VBUS is not detected yet.<br>1 = The VBUS is detected.                 |
| [30:25] | <b>Reserved</b> | Reserved.                                                                                            |
| [24]    | <b>WKEN</b>     | <b>Wake-up Enable Bit</b><br>0 = The wake-up function Disabled.<br>1 = The wake-up function Enabled. |
| [23:10] | <b>Reserved</b> | Reserved.                                                                                            |
| [9]     | <b>PHYEN</b>    | <b>PHY Suspend Enable Bit</b><br>0 = The USB PHY is suspend.<br>1 = The USB PHY is not suspend.      |
| [8]     | <b>DPPUEN</b>   | <b>DP Pull-up</b><br>0 = Pull-up resistor on D+ Disabled.<br>1 = Pull-up resistor on D+ Enabled.     |
| [7:0]   | <b>Reserved</b> | Reserved.                                                                                            |

## 6.32 USB 2.0 Host Controller (USBH)

### 6.32.1 Overview

This chip is equipped with a USB 2.0 HS/FS Host Controller (USBH) that supports Enhanced Host Controller Interface (EHCI) and Open Host Controller Interface (OpenHCI, OHCI) Specification, a register-level description of a host controller, to manage the devices and data transfer of Universal Serial Bus (USB).

The USBH supports an integrated Root Hub with a USB port, a DMA for real-time data transfer between system memory and USB bus, port power control and port over current detection.

The USBH is responsible for detecting the connect and disconnect of USB devices, managing data transfer, collecting status and activity of USB bus, providing power control and detecting over current of attached USB devices.

### 6.32.2 Features

- Compliant with Universal Serial Bus (USB) Specification Revision 2.0.
- Supports Enhanced Host Controller Interface (EHCI) Specification Revision 1.0
- Supports Open Host Controller Interface (OpenHCI) Specification Revision 1.0.
- Supports high-speed (480Mbps), full-speed (12Mbps) and low-speed (1.5Mbps) USB devices.
- Supports Control, Bulk, Interrupt, Isochronous and Split transfers.
- Supports an integrated Root Hub.
- Supports a port routing logic to route full/low speed device to OHCI controller.
- Supports two USB host port shared with USB device (OTG function).
- Supports port power control and port over current detection.
- Supports DMA for real-time data transfer.

## 6.32.3 Block Diagram



Figure 6.32-1 USB 2.0 FS Host Controller Block Diagram

### 6.32.4 Basic Configuration

#### 6.32.4.1 USBH EHCI Controller Basic Configuration

- Clock source Configuration
  - Select the source of USBH engine clock on USBSEL (CLK\_CLKSEL0[8]).
  - Select the clock divider number of USBH engine clock on USBDIV (CLK\_CLKDIV0[7:4]).
  - Enable USBH engine clock in HSUSBHCKEN (CLK\_AHBCLK[16]).
- Reset Configuration
  - Reset USBH controller in UHC20RST (SYS\_IPRST0[16]).

#### 6.32.4.2 USBH OHCI Controller Basic Configuration

- Clock source Configuration
  - Select the source of USBH engine clock on USBSEL (CLK\_CLKSEL0[8]).
  - Select the clock divider number of USBH engine clock on USBDIV (CLK\_CLKDIV0[7:4]).
  - Enable USBH engine clock in HSUSBHCKEN (CLK\_AHBCLK[16]).
- Reset Configuration
  - Reset USBH controller in UHC20RST (SYS\_IPRST0[16]).
- Pin Configuration

| Group | Pin Name    | GPIO              | MFP   |
|-------|-------------|-------------------|-------|
| USB   | USB_D+      | PA.14             | MFP14 |
|       | USB_D-      | PA.13             | MFP14 |
|       | USB_OTG_ID  | PA.15             | MFP14 |
|       | USB_VBUS    | PA.12             | MFP14 |
|       | USB_VBUS_EN | PB.6, PB.15       | MFP14 |
|       | USB_VBUS_ST | PB.7, PC.14, PD.4 | MFP14 |

### 6.32.5 Functional Description

#### 6.32.5.1 EHCI Controller

The EHCI is interfaced with the system through AHB interface. Whenever the CPU wants to initiate a register read or register write, it uses the AHB slave I/F signals and performs the necessary operation (register read writes). The CPU acts as a bus master, having initiated this transfer. At that time, EHCI acts as a target and responds to the transfer initiated by the system software. For example, if the CPU wants to write into one of the memory mapped registers of EHCI, it says the address and value to be written into that addressed register. EHCI targets the register by using that address and fills the register with the value specified by the software. If it is a register read, EHCI gets the value from the addressed register and puts it on the system bus.

Likewise, when the EHCI wants to perform a data transfer, it acts as a master and initiates a data transfer. At that time, the system memory acts as a bus target. EHCI, as a master can perform two types of data transfers, from EHCI to the system memory and from system memory to the EHCI. When the EHCI wants the data to be moved from the downstream USB2.0 device to the system memory, it initiates a memory write transfer by accessing the memory interfacing signals. EHCI writes the control word (write), data and data count to be moved to the system memory. The memory controller accepts the data and moves it to the memory. If the data has to be moved from memory to

the downstream device, the EHCI issue a read transfer to system bus. The memory controller gives data through the memory interfacing signals. EHCI accepts the data and moves them to the downstream device.

#### 6.32.5.2 OHCI Controller

##### AHB Interface

The OpenHCI Host Controller is connected to the system by the AHB bus. The design requires both master and slave bus operations. As a master, the Host Controller is responsible for running cycles on the AHB bus to access EDs and TDs as well as transferring data between memory and the local data buffer. As a slave, the Host Controller monitors the cycles on the AHB bus and determines when to respond to these cycles. Configuration and non-real-time control access to the Host Controller operational registers are through the AHB bus slave interface.

##### Host Controller

The host controller includes 5 functional blocks, including List Processing, Frame Management, Interrupt Processing, Host Controller Bus Master and Data Buffer.

The List Processor manages the data structures from the Host Controller Driver and coordinates all activity within the Host Controller.

The Frame Management is responsible for managing the frame specific tasks required by the USB specification and the OpenHCI specification. These tasks are:

- Management of the OpenHCI frame specific Operational Registers
- Operation of the Largest Data Packet Counter.
- Performing frame qualifications on USB Transaction requests to the SIE.
- Generate SOF token requests to the SIE.

Interrupts are the communication method for HC-initiated communication with the Host Controller Driver. There are several events that may trigger an interrupt from the Host Controller. Each specific event sets a specific bit in the HcInterruptStatus register.

The Host Controller Bus Master is the central block in the data path. The Host Controller Bus Master coordinates all access to the AHB Interface. There are two sources of bus mastering within Host Controller: the List Processor and the Data Buffer Engine.

The Data Buffer serves as the data interface between the Bus Master and the SIE. It is a combination of a 64-byte latched based bi-directional asynchronous FIFO and a single DWORD AHB Holding Register.

##### USB Interface

The USB interface includes the integrated Root Hub with an USB port, Port 1 as well as the Serial Interface Engine (SIE) and USB clock generator. The interface combines responsibility for executing bus transactions requested by the HC as well as the hub and port management specified by USB.

The SIE is responsible for managing all transactions to the USB. It controls the bus protocol, packet generation/extraction, data parallel-to-serial conversion, CRC coding, bit stuffing, and NRZI encoding. All transactions on the USB are requested from the List Processor and Frame Manager.

The Root Hub is a collection of ports that are individually controlled and a hub that maintains control/status over functions common to all ports.

**6.32.6 Register Map**

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

| Register                       | Offset          | R/W | Description                                    | Reset Value |
|--------------------------------|-----------------|-----|------------------------------------------------|-------------|
| <b>USBH Base Address:</b>      |                 |     |                                                |             |
| <b>USBH_BA = 0x4000_9000</b>   |                 |     |                                                |             |
| <b>HSUSBH_BA = 0x4001_A000</b> |                 |     |                                                |             |
| <b>HcRevision</b>              | USBH_BA+0x000   | R   | Host Controller Revision Register              | 0x0000_0110 |
| <b>HcControl</b>               | USBH_BA+0x004   | R/W | Host Controller Control Register               | 0x0000_0000 |
| <b>HcCommandStatus</b>         | USBH_BA+0x008   | R/W | Host Controller Command Status Register        | 0x0000_0000 |
| <b>HcInterruptStatus</b>       | USBH_BA+0x00C   | R/W | Host Controller Interrupt Status Register      | 0x0000_0000 |
| <b>HcInterruptEnable</b>       | USBH_BA+0x010   | R/W | Host Controller Interrupt Enable Register      | 0x0000_0000 |
| <b>HcInterruptDisable</b>      | USBH_BA+0x014   | R/W | Host Controller Interrupt Disable Register     | 0x0000_0000 |
| <b>HcHCCA</b>                  | USBH_BA+0x018   | R/W | Host Controller Communication Area Register    | 0x0000_0000 |
| <b>HcPeriodCurrentED</b>       | USBH_BA+0x01C   | R/W | Host Controller Period Current ED Register     | 0x0000_0000 |
| <b>HcControlHeadED</b>         | USBH_BA+0x020   | R/W | Host Controller Control Head ED Register       | 0x0000_0000 |
| <b>HcControlCurrentED</b>      | USBH_BA+0x024   | R/W | Host Controller Control Current ED Register    | 0x0000_0000 |
| <b>HcBulkHeadED</b>            | USBH_BA+0x028   | R/W | Host Controller Bulk Head ED Register          | 0x0000_0000 |
| <b>HcBulkCurrentED</b>         | USBH_BA+0x02C   | R/W | Host Controller Bulk Current ED Register       | 0x0000_0000 |
| <b>HcDoneHead</b>              | USBH_BA+0x030   | R/W | Host Controller Done Head Register             | 0x0000_0000 |
| <b>HcFmInterval</b>            | USBH_BA+0x034   | R/W | Host Controller Frame Interval Register        | 0x0000_2EDF |
| <b>HcFmRemaining</b>           | USBH_BA+0x038   | R   | Host Controller Frame Remaining Register       | 0x0000_0000 |
| <b>HcFmNumber</b>              | USBH_BA+0x03C   | R   | Host Controller Frame Number Register          | 0x0000_0000 |
| <b>HcPeriodicStart</b>         | USBH_BA+0x040   | R/W | Host Controller Periodic Start Register        | 0x0000_0000 |
| <b>HcLSThreshold</b>           | USBH_BA+0x044   | R/W | Host Controller Low-speed Threshold Register   | 0x0000_0628 |
| <b>HcRhDescriptorA</b>         | USBH_BA+0x048   | R/W | Host Controller Root Hub Descriptor A Register | 0x0000_0902 |
| <b>HcRhDescriptorB</b>         | USBH_BA+0x04C   | R/W | Host Controller Root Hub Descriptor B Register | 0x0000_0000 |
| <b>HcRhStatus</b>              | USBH_BA+0x050   | R/W | Host Controller Root Hub Status Register       | 0x0000_0000 |
| <b>HcRhPortStatus1</b>         | USBH_BA+0x058   | R/W | Host Controller Root Hub Port Status [1]       | 0x0000_0000 |
| <b>HcPhyControl</b>            | USBH_BA+0x200   | R/W | Host Controller PHY Control Register           | 0x0000_0000 |
| <b>HcMiscControl</b>           | USBH_BA+0x204   | R/W | Host Controller Miscellaneous Control Register | 0x0000_0000 |
| <b>EHCVNR</b>                  | HSUSBH_BA+0x000 | R   | EHCI Version Number Register                   | 0x0095_0020 |
| <b>EHCSPR</b>                  | HSUSBH_BA+0x004 | R   | EHCI Structural Parameters Register            | 0x0000_0012 |

| Register | Offset          | R/W | Description                                    | Reset Value |
|----------|-----------------|-----|------------------------------------------------|-------------|
| EHCCPR   | HSUSBH_BA+0x008 | R   | EHCI Capability Parameters Register            | 0x0000_0000 |
| UCMDR    | HSUSBH_BA+0x020 | R/W | USB Command Register                           | 0x0008_0000 |
| USTSR    | HSUSBH_BA+0x024 | R/W | USB Status Register                            | 0x0000_1000 |
| UIENR    | HSUSBH_BA+0x028 | R/W | USB Interrupt Enable Register                  | 0x0000_0000 |
| UFINDR   | HSUSBH_BA+0x02C | R/W | USB Frame Index Register                       | 0x0000_0000 |
| UPFLBAR  | HSUSBH_BA+0x034 | R/W | USB Periodic Frame List Base Address Register  | 0x0000_0000 |
| UCALAR   | HSUSBH_BA+0x038 | R/W | USB Current Asynchronous List Address Register | 0x0000_0000 |
| UASSTR   | HSUSBH_BA+0x03C | R/W | USB Asynchronous Schedule Sleep Timer Register | 0x0000_0BD6 |
| UCFGR    | HSUSBH_BA+0x060 | R/W | USB Configure Flag Register                    | 0x0000_0000 |
| UPSCR0   | HSUSBH_BA+0x064 | R/W | USB Port 0 Status and Control Register         | 0x0000_2000 |
| UPSCR1   | HSUSBH_BA+0x068 | R/W | USB Port 1 Status and Control Register         | 0x0000_2000 |
| USBPCR0  | HSUSBH_BA+0x0C4 | R/W | USB PHY 0 Control Register                     | 0x0000_0060 |
| USBPCR1  | HSUSBH_BA+0x0C8 | R/W | USB PHY 1 Control Register                     | 0x0000_0020 |

### 6.32.7 Register Description

#### Host Controller Revision Register (HcRevision)

| Register   | Offset        | R/W | Description                       |  |  |  |  | Reset Value |
|------------|---------------|-----|-----------------------------------|--|--|--|--|-------------|
| HcRevision | USBH_BA+0x000 | R   | Host Controller Revision Register |  |  |  |  | 0x0000_0110 |

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

| Bits   | Description |                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                  |
| [7:0]  | REV         | <b>Revision Number</b><br>Indicates the Open HCI Specification revision number implemented by the Hardware.<br>Host Controller supports 1.1 specification.<br>(X.Y = XYh). |

**Host Controller Control Register (HcControl)**

| Register  | Offset        | R/W | Description                      |  |  |  | Reset Value |
|-----------|---------------|-----|----------------------------------|--|--|--|-------------|
| HcControl | USBH_BA+0x004 | R/W | Host Controller 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  |
| HCFS     |    | BLE | CLE | IE | PLE | CBSR |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [7:6]  | HCFS        | <p><b>Host Controller Functional State</b></p> <p>This field sets the Host Controller state. The Controller may force a state change from USBSUSPEND to USBRESUME after detecting resume signaling from a downstream port. States are:</p> <p>00 = USBSUSPEND.<br/>01 = USBOPERATIONAL.<br/>10 = USBRESUME.<br/>11 = USBRESET.</p>                                                                                                                         |
| [5]    | BLE         | <p><b>Bulk List Enable Bit</b></p> <p>0 = Processing of the Bulk list after next SOF (Start-Of-Frame) Disabled.<br/>1 = Processing of the Bulk list in the next frame Enabled.</p>                                                                                                                                                                                                                                                                         |
| [4]    | CLE         | <p><b>Control List Enable Bit</b></p> <p>0 = Processing of the Control list after next SOF (Start-Of-Frame) Disabled.<br/>1 = Processing of the Control list in the next frame Enabled.</p>                                                                                                                                                                                                                                                                |
| [3]    | IE          | <p><b>Isochronous List Enable Bit</b></p> <p>Both ISOEn and PLE (HcControl[2]) high enables Host Controller to process the Isochronous list. Either ISOEn or PLE (HcControl[2]) is low disables Host Controller to process the Isochronous list.</p> <p>0 = Processing of the Isochronous list after next SOF (Start-Of-Frame) Disabled.<br/>1 = Processing of the Isochronous list in the next frame Enabled, if the PLE (HcControl[2]) is high, too.</p> |

|       |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2]   | <b>PLE</b>  | <b>Periodic List Enable Bit</b><br>When set, this bit enables processing of the Periodic (interrupt and isochronous) list. The Host Controller checks this bit prior to attempting any periodic transfers in a frame.<br>0 = Processing of the Periodic (Interrupt and Isochronous) list after next SOF (Start-Of-Frame) Disabled.<br>1 = Processing of the Periodic (Interrupt and Isochronous) list in the next frame Enabled.<br><b>Note:</b> To enable the processing of the Isochronous list, user has to set both PLE and IE (HcControl[3]) high.                                                                                                                                                                                         |
| [1:0] | <b>CBSR</b> | <b>Control Bulk Service Ratio</b><br>This specifies the service ratio between Control and Bulk EDs. Before processing any of the non-periodic lists, HC must compare the ratio specified with its internal count on how many nonempty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this Value.<br>00 = Number of Control EDs over Bulk EDs served is 1:1.<br>01 = Number of Control EDs over Bulk EDs served is 2:1.<br>10 = Number of Control EDs over Bulk EDs served is 3:1.<br>11 = Number of Control EDs over Bulk EDs served is 4:1. |

**Host Controller Command Status Register (HcCommandStatus)**

| Register        | Offset        | R/W | Description                             |  |  |  | Reset Value |
|-----------------|---------------|-----|-----------------------------------------|--|--|--|-------------|
| HcCommandStatus | USBH_BA+0x008 | R/W | Host Controller Command Status Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [17:16] | SOC         | <b>Schedule Overrun Count</b><br>These bits are incremented on each scheduling overrun error. It is initialized to 00b and wraps around at 11b. This will be incremented when a scheduling overrun is detected even if SO (HcInterruptStatus[0]) has already been set.                                                                                                                                                   |
| [15:3]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |
| [2]     | BLF         | <b>Bulk List Filled</b><br>Set high to indicate there is an active TD on the Bulk list. This bit may be set by either software or the Host Controller and cleared by the Host Controller each time it begins processing the head of the Bulk list.<br>0 = No active TD found or Host Controller begins to process the head of the Bulk list.<br>1 = An active TD added or found on the Bulk list.                        |
| [1]     | CLF         | <b>Control List Filled</b><br>Set high to indicate there is an active TD on the Control List. It may be set by either software or the Host Controller and cleared by the Host Controller each time it begins processing the head of the Control List.<br>0 = No active TD found or Host Controller begins to process the head of the Control list.<br>1 = An active TD added or found on the Control list.               |
| [0]     | HCR         | <b>Host Controller Reset</b><br>This bit is set to initiate the software reset of Host Controller. This bit is cleared by the Host Controller, upon completion of the reset operation.<br>This bit, when set, didn't reset the Root Hub and no subsequent reset signaling be asserted to its downstream ports.<br>0 = Host Controller is not in software reset state.<br>1 = Host Controller is in software reset state. |

**Host Controller Interrupt Status Register (HcInterruptStatus)**

| Register          | Offset        | R/W | Description                               |  |  |  | Reset Value |
|-------------------|---------------|-----|-------------------------------------------|--|--|--|-------------|
| HcInterruptStatus | USBH_BA+0x00C | R/W | Host Controller 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 | RHSC | FNO | Reserved | RD | SF | WDH | SO |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                               |
| [6]    | RHSC        | <p><b>Root Hub Status Change</b><br/>           This bit is set when the content of HcRhStatus or the content of HcRhPortStatus1 register has changed.<br/>           0 = The content of HcRhStatus and the content of HcRhPortStatus1 register didn't change.<br/>           1 = The content of HcRhStatus or the content of HcRhPortStatus1 register has changed.</p> |
| [5]    | FNO         | <p><b>Frame Number Overflow</b><br/>           This bit is set when bit 15 of Frame Number changes from 1 to 0 or from 0 to 1.<br/>           0 = The bit 15 of Frame Number didn't change.<br/>           1 = The bit 15 of Frame Number changes from 1 to 0 or from 0 to 1.</p>                                                                                       |
| [4]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                               |
| [3]    | RD          | <p><b>Resume Detected</b><br/>           Set when Host Controller detects resume signaling on a downstream port.<br/>           0 = No resume signaling detected on a downstream port.<br/>           1 = Resume signaling detected on a downstream port.</p>                                                                                                           |
| [2]    | SF          | <p><b>Start of Frame</b><br/>           Set when the Frame Management functional block signals a 'Start of Frame' event. Host Control generates a SOF token at the same time.<br/>           0 = Not the start of a frame.<br/>           1 = Indicate the start of a frame and Host Controller generates a SOF token.</p>                                              |
| [1]    | WDH         | <p><b>Write Back Done Head</b><br/>           Set after the Host Controller has written HcDoneHead to HccaDoneHead. Further updates of the HccaDoneHead will not occur until this bit has been cleared.<br/>           0 = Host Controller didn't update HccaDoneHead.<br/>           1 = Host Controller has written HcDoneHead to HccaDoneHead.</p>                   |

|     |    |                                                                                                                                                                                  |
|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | SO | <b>Scheduling Overrun</b><br>Set when the List Processor determines a Schedule Overrun has occurred.<br>0 = Schedule Overrun didn't occur.<br>1 = Schedule Overrun has occurred. |
|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Host Controller Interrupt Enable Register (HcInterruptEnable)

| Register          | Offset        | R/W | Description                               |  |  |  | Reset Value |
|-------------------|---------------|-----|-------------------------------------------|--|--|--|-------------|
| HcInterruptEnable | USBH_BA+0x010 | R/W | Host Controller Interrupt Enable Register |  |  |  | 0x0000_0000 |

|          |          |     |          |    |    |     |    |
|----------|----------|-----|----------|----|----|-----|----|
| 31       | 30       | 29  | 28       | 27 | 26 | 25  | 24 |
| MIE      | Reserved |     |          |    |    |     |    |
| 23       | 22       | 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 | RHSC     | FNO | Reserved | RD | SF | WDH | SO |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | MIE         | <p><b>Master Interrupt Enable Bit</b></p> <p>This bit is a global interrupt enable. A write of '1' allows interrupts to be enabled via the specific enable bits listed above.</p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]), FNO (HcInterruptStatus[5]), RD (HcInterruptStatus[3]), SF (HcInterruptStatus[2]), WDH (HcInterruptStatus[1]) or SO (HcInterruptStatus[0]) Enabled if the corresponding bit in HcInterruptEnable is high.</p> <p>Read Operation:</p> <p>0 = Interrupt generation due to RHSC (HcInterruptStatus[6]), FNO (HcInterruptStatus[5]), RD (HcInterruptStatus[3]), SF (HcInterruptStatus[2]), WDH (HcInterruptStatus[1]) or SO (HcInterruptStatus[0]) Disabled even if the corresponding bit in HcInterruptEnable is high.</p> <p>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]), FNO (HcInterruptStatus[5]), RD (HcInterruptStatus[3]), SF (HcInterruptStatus[2]), WDH (HcInterruptStatus[1]) or SO (HcInterruptStatus[0]) Enabled if the corresponding bit in HcInterruptEnable is high.</p> |
| [30:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [6]    | RHSC        | <p><b>Root Hub Status Change Enable Bit</b></p> <p>Write Operation:</p> <p>0 = No effect.</p> <p>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]) Enabled.</p> <p>Read Operation:</p> <p>0 = Interrupt generation due to RHSC (HcInterruptStatus[6]) Disabled.</p> <p>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]) Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|     |          |                                                                                                                                                                                                                                                                                                                        |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5] | FNO      | <b>Frame Number Overflow Enable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to FNO (HcInterruptStatus[5]) Enabled.<br>Read Operation:<br>0 = Interrupt generation due to FNO (HcInterruptStatus[5]) Disabled.<br>1 = Interrupt generation due to FNO (HcInterruptStatus[5]) Enabled. |
| [4] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                              |
| [3] | RD       | <b>Resume Detected Enable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to RD (HcInterruptStatus[3]) Enabled.<br>Read Operation:<br>0 = Interrupt generation due to RD (HcInterruptStatus[3]) Disabled.<br>1 = Interrupt generation due to RD (HcInterruptStatus[3]) Enabled.          |
| [2] | SF       | <b>Start of Frame Enable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to SF (HcInterruptStatus[2]) Enabled.<br>Read Operation:<br>0 = Interrupt generation due to SF (HcInterruptStatus[2]) Disabled.<br>1 = Interrupt generation due to SF (HcInterruptStatus[2]) Enabled.           |
| [1] | WDH      | <b>Write Back Done Head Enable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to WDH (HcInterruptStatus[1]) Enabled.<br>Read Operation:<br>0 = Interrupt generation due to WDH (HcInterruptStatus[1]) Disabled.<br>1 = Interrupt generation due to WDH (HcInterruptStatus[1]) Enabled.  |
| [0] | SO       | <b>Scheduling Overrun Enable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to SO (HcInterruptStatus[0]) Enabled.<br>Read Operation:<br>0 = Interrupt generation due to SO (HcInterruptStatus[0]) Disabled.<br>1 = Interrupt generation due to SO (HcInterruptStatus[0]) Enabled.       |

**Host Controller Interrupt Disable Register (HcInterruptDisable)**

| Register           | Offset        | R/W | Description                                |  |  |  | Reset Value |
|--------------------|---------------|-----|--------------------------------------------|--|--|--|-------------|
| HcInterruptDisable | USBH_BA+0x014 | R/W | Host Controller Interrupt Disable Register |  |  |  | 0x0000_0000 |

|          |          |     |          |    |    |     |    |
|----------|----------|-----|----------|----|----|-----|----|
| 31       | 30       | 29  | 28       | 27 | 26 | 25  | 24 |
| MIE      | Reserved |     |          |    |    |     |    |
| 23       | 22       | 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 | RHSC     | FNO | Reserved | RD | SF | WDH | SO |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | MIE         | <b>Master Interrupt Disable Bit</b><br>Global interrupt disable. Writing '1' to disable all interrupts.<br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]), FNO (HcInterruptStatus[5]), RD (HcInterruptStatus[3]), SF (HcInterruptStatus[2]), WDH (HcInterruptStatus[1]) or SO (HcInterruptStatus[0]) Disabled if the corresponding bit in HcInterruptEnable is high.<br>Read Operation:<br>0 = Interrupt generation due to RHSC (HcInterruptStatus[6]), FNO (HcInterruptStatus[5]), RD (HcInterruptStatus[3]), SF (HcInterruptStatus[2]), WDH (HcInterruptStatus[1]) or SO (HcInterruptStatus[0]) Disabled even if the corresponding bit in HcInterruptEnable is high.<br>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]), FNO (HcInterruptStatus[5]), RD (HcInterruptStatus[3]), SF (HcInterruptStatus[2]), WDH (HcInterruptStatus[1]) or SO (HcInterruptStatus[0]) Enabled if the corresponding bit in HcInterruptEnable is high. |
| [30:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [6]    | RHSC        | <b>Root Hub Status Change Disable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]) Disabled.<br>Read Operation:<br>0 = Interrupt generation due to RHSC (HcInterruptStatus[6]) Disabled.<br>1 = Interrupt generation due to RHSC (HcInterruptStatus[6]) Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [5]    | FNO         | <b>Frame Number Overflow Disable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to FNO (HcInterruptStatus[5]) Disabled.<br>Read Operation:<br>0 = Interrupt generation due to FNO (HcInterruptStatus[5]) Disabled.<br>1 = Interrupt generation due to FNO (HcInterruptStatus[5]) Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|     |          |                                                                                                                                                                                                                                                                                                                         |
|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                               |
| [3] | RD       | <b>Resume Detected Disable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to RD (HcInterruptStatus[3]) Disabled.<br>Read Operation:<br>0 = Interrupt generation due to RD (HcInterruptStatus[3]) Disabled.<br>1 = Interrupt generation due to RD (HcInterruptStatus[3]) Enabled.         |
| [2] | SF       | <b>Start of Frame Disable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to SF (HcInterruptStatus[2]) Disabled.<br>Read Operation:<br>0 = Interrupt generation due to SF (HcInterruptStatus[2]) Disabled.<br>1 = Interrupt generation due to SF (HcInterruptStatus[2]) Enabled.          |
| [1] | WDH      | <b>Write Back Done Head Disable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to WDH (HcInterruptStatus[1]) Disabled.<br>Read Operation:<br>0 = Interrupt generation due to WDH (HcInterruptStatus[1]) Disabled.<br>1 = Interrupt generation due to WDH (HcInterruptStatus[1]) Enabled. |
| [0] | SO       | <b>Scheduling Overrun Disable Bit</b><br>Write Operation:<br>0 = No effect.<br>1 = Interrupt generation due to SO (HcInterruptStatus[0]) Disabled.<br>Read Operation:<br>0 = Interrupt generation due to SO (HcInterruptStatus[0]) Disabled.<br>1 = Interrupt generation due to SO (HcInterruptStatus[0]) Enabled.      |

**Host Controller Communication Area Register (HcHCCA)**

| Register | Offset        | R/W | Description                                 |  |  |  | Reset Value |
|----------|---------------|-----|---------------------------------------------|--|--|--|-------------|
| HcHCCA   | USBH_BA+0x018 | R/W | Host Controller Communication Area Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                                 |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | <b>HCCA</b>     | <b>Host Controller Communication Area</b><br>Pointer to indicate base address of the Host Controller Communication Area (HCCA). |
| [7:0]  | <b>Reserved</b> | Reserved.                                                                                                                       |

Host Controller Period Current ED Register (HcPeriodCurrentED)

| Register          | Offset        | R/W | Description                                | Reset Value |
|-------------------|---------------|-----|--------------------------------------------|-------------|
| HcPeriodCurrentED | USBH_BA+0x01C | R/W | Host Controller Period Current ED Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                 |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | PCED        | <b>Periodic Current ED</b><br>Pointer to indicate physical address of the current Isochronous or Interrupt Endpoint Descriptor. |
| [3:0]  | Reserved    | Reserved.                                                                                                                       |

**Host Controller Control Head ED Register (HcControlHeadED)**

| Register        | Offset        | R/W | Description                              | Reset Value |
|-----------------|---------------|-----|------------------------------------------|-------------|
| HcControlHeadED | USBH_BA+0x020 | R/W | Host Controller Control Head ED Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                               |
|--------|-------------|---------------------------------------------------------------------------------------------------------------|
| [31:4] | CHED        | Control Head ED<br>Pointer to indicate physical address of the first Endpoint Descriptor of the Control list. |
| [3:0]  | Reserved    | Reserved.                                                                                                     |

**Host Controller Control Current ED Register (HcControlCurrentED)**

| Register           | Offset        | R/W | Description                                 |  |  |  |  | Reset Value |
|--------------------|---------------|-----|---------------------------------------------|--|--|--|--|-------------|
| HcControlCurrentED | USBH_BA+0x024 | R/W | Host Controller Control Current ED Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                    |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | CCED        | <b>Control Current Head ED</b><br>Pointer to indicate the physical address of the current Endpoint Descriptor of the Control list. |
| [3:0]  | Reserved    | Reserved.                                                                                                                          |

**Host Controller Bulk Head ED Register (HcBulkHeadED)**

| Register     | Offset        | R/W | Description                           |  |  |  | Reset Value |
|--------------|---------------|-----|---------------------------------------|--|--|--|-------------|
| HcBulkHeadED | USBH_BA+0x028 | R/W | Host Controller Bulk Head ED Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                    |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------|
| [31:4] | <b>BHED</b>     | <b>Bulk Head ED</b><br>Pointer to indicate the physical address of the first Endpoint Descriptor of the Bulk list. |
| [3:0]  | <b>Reserved</b> | Reserved.                                                                                                          |

**Host Controller Bulk Current Head ED Register (HcBulkCurrentED)**

| Register        | Offset        | R/W | Description                              | Reset Value |
|-----------------|---------------|-----|------------------------------------------|-------------|
| HcBulkCurrentED | USBH_BA+0x02C | R/W | Host Controller Bulk Current ED Register | 0x0000_0000 |

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

| Bits   | Description     |                                                                                                                   |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------|
| [31:4] | <b>BCED</b>     | <b>Bulk Current Head ED</b><br>Pointer to indicate the physical address of the current endpoint of the Bulk list. |
| [3:0]  | <b>Reserved</b> | Reserved.                                                                                                         |

**Host Controller Done Head Register (HcDoneHead)**

| Register   | Offset        | R/W | Description                        |  |  |  | Reset Value |
|------------|---------------|-----|------------------------------------|--|--|--|-------------|
| HcDoneHead | USBH_BA+0x030 | R/W | Host Controller Done Head Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                          |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | DH          | <b>Done Head</b><br>Pointer to indicate the physical address of the last completed Transfer Descriptor that was added to the Done queue. |
| [3:0]  | Reserved    | Reserved.                                                                                                                                |

**Host Controller Frame Interval Register (HcFmInterval)**

| Register     | Offset        | R/W | Description                             |  |  |  |  | Reset Value |
|--------------|---------------|-----|-----------------------------------------|--|--|--|--|-------------|
| HcFmInterval | USBH_BA+0x034 | R/W | Host Controller Frame Interval Register |  |  |  |  | 0x0000_2EDF |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                       |
|---------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>FIT</b>      | <b>Frame Interval Toggle</b><br>This bit is toggled by Host Controller Driver when it loads a new value into FI (HcFmInterval[13:0]).<br>0 = Host Controller Driver didn't load new value into FI (HcFmInterval[13:0]).<br>1 = Host Controller Driver loads a new value into FI (HcFmInterval[13:0]). |
| [30:16] | <b>FSMPS</b>    | <b>FS Largest Data Packet</b><br>This field specifies a value that is loaded into the Largest Data Packet Counter at the beginning of each frame.                                                                                                                                                     |
| [15:14] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                             |
| [13:0]  | <b>FI</b>       | <b>Frame Interval</b><br>This field specifies the length of a frame as (bit times - 1). For 12,000 bit times in a frame, a value of 11,999 is stored here.                                                                                                                                            |

Host Controller Frame Remaining Register (HcFmRemaining)

| Register      | Offset        | R/W | Description                              |  |  |  |  | Reset Value |
|---------------|---------------|-----|------------------------------------------|--|--|--|--|-------------|
| HcFmRemaining | USBH_BA+0x038 | R   | Host Controller Frame Remaining Register |  |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | FRT         | <b>Frame Remaining Toggle</b><br>This bit is loaded from the FIT (HcFmInterval[31]) whenever FR (HcFmRemaining[13:0]) reaches 0.                                                                                                                                                                                     |
| [30:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                            |
| [13:0]  | FR          | <b>Frame Remaining</b><br>When the Host Controller is in the USBOPERATIONAL state, this 14-bit field decrements each 12 MHz clock period. When the count reaches 0, (end of frame) the counter reloads with Frame Interval. In addition, the counter loads when the Host Controller transitions into USBOPERATIONAL. |

**Host Controller Frame Number Register (HcFmNumber)**

| Register   | Offset        | R/W | Description                           | Reset Value |
|------------|---------------|-----|---------------------------------------|-------------|
| HcFmNumber | USBH_BA+0x03C | R   | Host Controller Frame Number Register | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                        |
| [15:0]  | FN          | <b>Frame Number</b><br>This 16-bit incrementing counter field is incremented coincident with the re-load of FR (HcFmRemaining[13:0]). The count rolls over from 'FFFFh' to '0h.' |

**Host Controller Periodic Start Register (HcPeriodicStart)**

| Register        | Offset        | R/W | Description                             |  |  |  | Reset Value |
|-----------------|---------------|-----|-----------------------------------------|--|--|--|-------------|
| HcPeriodicStart | USBH_BA+0x040 | R/W | Host Controller Periodic Start 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 |    | PS |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| PS       |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                        |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                              |
| [13:0]  | PS          | <b>Periodic Start</b><br>This field contains a value used by the List Processor to determine where in a frame the Periodic List processing must begin. |

**Host Controller Low-speed Threshold Register (HcLSThreshold)**

| Register      | Offset        | R/W | Description                                  |  |  |  |  | Reset Value |
|---------------|---------------|-----|----------------------------------------------|--|--|--|--|-------------|
| HcLSThreshold | USBH_BA+0x044 | R/W | Host Controller Low-speed Threshold Register |  |  |  |  | 0x0000_0628 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                              |
| [11:0]  | LST         | <b>Low-speed Threshold</b><br>This field contains a value which is compared to the FR (HcFmRemaining[13:0]) field prior to initiating a Low-speed transaction. The transaction is started only if FR (HcFmRemaining[13:0]) >= this field. The value is calculated by Host Controller Driver with the consideration of transmission and setup overhead. |

**Host Controller Root Hub Descriptor A Register (HcRhDescriptorA)**

| Register        | Offset        | R/W | Description                                    |  |  |  | Reset Value |
|-----------------|---------------|-----|------------------------------------------------|--|--|--|-------------|
| HcRhDescriptorA | USBH_BA+0x048 | R/W | Host Controller Root Hub Descriptor A Register |  |  |  | 0x0000_0902 |

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

| Bits    | Description |                                                                                                                                                                                                                                                       |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:13] | Reserved    | Reserved.                                                                                                                                                                                                                                             |
| [12]    | NOCP        | <b>No over Current Protection</b><br>This bit describes how the over current status for the Root Hub ports reported.<br>0 = Over current status is reported.<br>1 = Over current status is not reported.                                              |
| [11]    | OCPM        | <b>over Current Protection Mode</b><br>This bit describes how the over current status for the Root Hub ports reported. This bit is only valid when NOCP (HcRhDescriptorA[12]) is cleared.<br>0 = Global Over current.<br>1 = Individual Over current. |
| [10:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                             |
| [8]     | PSM         | <b>Power Switching Mode</b><br>This bit is used to specify how the power switching of the Root Hub ports is controlled.<br>0 = Global Switching.<br>1 = Individual Switching.                                                                         |
| [7:0]   | NDP         | <b>Number Downstream Ports</b><br>USB host control supports two downstream ports and only one port is available in this series of chip.                                                                                                               |

**Host Controller Root Hub Descriptor B Register (HcRhDescriptorB)**

| Register        | Offset        | R/W | Description                                    |  |  |  | Reset Value |
|-----------------|---------------|-----|------------------------------------------------|--|--|--|-------------|
| HcRhDescriptorB | USBH_BA+0x04C | R/W | Host Controller Root Hub Descriptor B Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | PPCM        | <b>Port Power Control Mask</b><br>Global power switching. This field is only valid if PowerSwitchingMode is set (individual port switching). When set, the port only responds to individual port power switching commands (Set/ClearPortPower). When cleared, the port only responds to global power switching commands (Set/ClearGlobalPower).<br>0 = Port power controlled by global power switching.<br>1 = Port power controlled by port power switching.<br><b>Note:</b> PPCM[15:2] and PPCM[0] are reserved. |
| [15:0]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

**Host Controller Root Hub Status Register (HcRhStatus)**

| Register   | Offset        | R/W | Description                              |  |  |  | Reset Value |
|------------|---------------|-----|------------------------------------------|--|--|--|-------------|
| HcRhStatus | USBH_BA+0x050 | R/W | Host Controller Root Hub Status Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>CRWE</b><br><b>Clear Remote Wake-up Enable Bit</b><br>This bit is use to clear DRWE (HcRhStatus[15]).<br>This bit always read as zero.<br>Write Operation:<br>0 = No effect.<br>1 = Clear DRWE (HcRhStatus[15]).                                                                                                                                                                             |
| [31:18] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                                                    |
| [17]    | <b>OCIC</b><br><b>over Current Indicator Change</b><br>This bit is set by hardware when a change has occurred in OCI (HcRhStatus[1]).<br>Write 1 to clear this bit to zero.<br>0 = OCI (HcRhStatus[1]) didn't change.<br>1 = OCI (HcRhStatus[1]) change.                                                                                                                                        |
| [16]    | <b>LPSC</b><br><b>Set Global Power</b><br>In global power mode (PSM (HcRhDescriptorA[8]) = 0), this bit is written to one to enable power to all ports.<br>This bit always read as zero.<br>Write Operation:<br>0 = No effect.<br>1 = Set global power.                                                                                                                                         |
| [15]    | <b>DRWE</b><br><b>Device Remote Wakeup Enable Bit</b><br>This bit controls if port's Connect Status Change as a remote wake-up event.<br>Write Operation:<br>0 = No effect.<br>1 = Connect Status Change as a remote wake-up event Enabled.<br>Read Operation:<br>0 = Connect Status Change as a remote wake-up event Disabled.<br>1 = Connect Status Change as a remote wake-up event Enabled. |

|        |            |                                                                                                                                                                                                                                                    |
|--------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [14:2] | Reserved   | Reserved.                                                                                                                                                                                                                                          |
| [1]    | <b>OCI</b> | <b>over Current Indicator</b><br>This bit reflects the state of the over current status pin. This field is only valid if NOCP (HcRhDesA[12]) and OCPM (HcRhDesA[11]) are cleared.<br>0 = No over current condition.<br>1 = Over current condition. |
| [0]    | <b>LPS</b> | <b>Clear Global Power</b><br>In global power mode (PSM (HcRhDescriptorA[8]) = 0), this bit is written to one to clear all ports' power.<br>This bit always read as zero.<br>Write Operation:<br>0 = No effect.<br>1 = Clear global power.          |

**Host Controller Root Hub Port Status (HcRhPrt [1])**

| Register        | Offset        | R/W | Description                              |  |  |  | Reset Value |
|-----------------|---------------|-----|------------------------------------------|--|--|--|-------------|
| HcRhPortStatus1 | USBH_BA+0x058 | R/W | Host Controller Root Hub Port Status [1] |  |  |  | 0x0000_0000 |

|          |    |    |      |      |      |      |     |
|----------|----|----|------|------|------|------|-----|
| 31       | 30 | 29 | 28   | 27   | 26   | 25   | 24  |
| Reserved |    |    |      |      |      |      |     |
| 23       | 22 | 21 | 20   | 19   | 18   | 17   | 16  |
| Reserved |    |    | PRSC | OCIC | PSSC | PESC | CSC |
| 15       | 14 | 13 | 12   | 11   | 10   | 9    | 8   |
| Reserved |    |    |      |      |      | LSDA | PPS |
| 7        | 6  | 5  | 4    | 3    | 2    | 1    | 0   |
| Reserved |    |    | PRS  | POCI | PSS  | PES  | CCS |

| Bits    | Description |                                                                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                        |
| [20]    | PRSC        | <b>Port Reset Status Change</b><br>This bit indicates that the port reset signal has completed.<br>Write 1 to clear this bit to zero.<br>0 = Port reset is not complete.<br>1 = Port reset is complete.                                                                          |
| [19]    | OCIC        | <b>Port over Current Indicator Change</b><br>This bit is set when POCI (HcRhPortStatus1[3]) changes.<br>Write 1 to clear this bit to zero.<br>0 = POCI (HcRhPortStatus1[3]) didn't change.<br>1 = POCI (HcRhPortStatus1[3]) changes.                                             |
| [18]    | PSSC        | <b>Port Suspend Status Change</b><br>This bit indicates the completion of the selective resume sequence for the port.<br>Write 1 to clear this bit to zero.<br>0 = Port resume is not completed.<br>1 = Port resume completed.                                                   |
| [17]    | PESC        | <b>Port Enable Status Change</b><br>This bit indicates that the port has been disabled (PES (HcRhPortStatus1[1]) cleared) due to a hardware event.<br>Write 1 to clear this bit to zero.<br>0 = PES (HcRhPortStatus1[1]) didn't change.<br>1 = PES (HcRhPortStatus1[1]) changed. |

|         |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]    | CSC      | <b>Connect Status Change</b><br>This bit indicates connect or disconnect event has been detected (CCS (HcRhPortStatus1[0]) changed).<br>Write 1 to clear this bit to zero.<br>0 = No connect/disconnect event (CCS (HcRhPortStatus1[0]) didn't change).<br>1 = Hardware detection of connect/disconnect event (CCS (HcRhPortStatus1[0]) changed).                                                                                                                                                            |
| [15:10] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [9]     | LSDA     | <b>Low Speed Device Attached (Read) or Clear Port Power (Write)</b><br>This bit defines the speed (and bus idle) of the attached device. It is only valid when CCS (HcRhPortStatus1[0]) is set.<br>This bit is also used to clear port power.<br>Write Operation:<br>0 = No effect.<br>1 = Clear PPS (HcRhPortStatus1[8]).<br>Read Operation:<br>0 = Full Speed device.<br>1 = Low-speed device.                                                                                                             |
| [8]     | PPS      | <b>Port Power Status</b><br>This bit reflects the power state of the port regardless of the power switching mode.<br>Write Operation:<br>0 = No effect.<br>1 = Port Power Enabled.<br>Read Operation:<br>0 = Port power is Disabled.<br>1 = Port power is Enabled.                                                                                                                                                                                                                                           |
| [7:5]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [4]     | PRS      | <b>Port Reset Status</b><br>This bit reflects the reset state of the port.<br>Write Operation:<br>0 = No effect.<br>1 = Set port reset.<br>Read Operation<br>0 = Port reset signal is not active.<br>1 = Port reset signal is active.                                                                                                                                                                                                                                                                        |
| [3]     | POCI     | <b>Port over Current Indicator (Read) or Clear Port Suspend (Write)</b><br>This bit reflects the state of the over current status pin dedicated to this port. This field is only valid if NOCP (HcRhDescriptorA[12]) is cleared and OCPM (HcRhDescriptorA[11]) is set.<br>This bit is also used to initiate the selective result sequence for the port.<br>Write Operation:<br>0 = No effect.<br>1 = Clear port suspend.<br>Read Operation:<br>0 = No over current condition.<br>1 = Over current condition. |

|     |     |                                                                                                                                                                                                                              |
|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | PSS | <b>Port Suspend Status</b><br>This bit indicates the port is suspended<br>Write Operation:<br>0 = No effect.<br>1 = Set port suspend.<br>Read Operation:<br>0 = Port is not suspended.<br>1 = Port is selectively suspended. |
| [1] | PES | <b>Port Enable Status</b><br>Write Operation:<br>0 = No effect.<br>1 = Set port enable.<br>Read Operation:<br>0 = Port Disabled.<br>1 = Port Enabled.                                                                        |
| [0] | CCS | <b>CurrentConnectStatus (Read) or ClearPortEnable Bit (Write)</b><br>Write Operation:<br>0 = No effect.<br>1 = Clear port enable.<br>Read Operation:<br>0 = No device connected.<br>1 = Device connected.                    |

**Host Controller PHY Control Register (HcPhyControl)**

| Register     | Offset        | R/W | Description                          |  |  |  | Reset Value |
|--------------|---------------|-----|--------------------------------------|--|--|--|-------------|
| HcPhyControl | USBH_BA+0x200 | R/W | Host Controller PHY Control Register |  |  |  | 0x0000_0000 |

|          |    |    |    |        |          |    |    |
|----------|----|----|----|--------|----------|----|----|
| 31       | 30 | 29 | 28 | 27     | 26       | 25 | 24 |
| Reserved |    |    |    | STBYEN | Reserved |    |    |
| 23       | 22 | 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:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                   |
| [27]    | STBYEN      | <p><b>USB Transceiver Standby Enable Bit</b></p> <p>This bit controls if USB transceiver could enter the standby mode to reduce power consumption.</p> <p>0 = The USB transceiver would never enter the standby mode.</p> <p>1 = The USB transceiver will enter standby mode while port is in power off state (port power is inactive).</p> |
| [26:0]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                   |

**Host Controller Miscellaneous Control Register (HcMiscControl)**

| Register      | Offset        | R/W | Description                                    |  |  |  | Reset Value |
|---------------|---------------|-----|------------------------------------------------|--|--|--|-------------|
| HcMiscControl | USBH_BA+0x204 | R/W | Host Controller Miscellaneous 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 |    |    |    | OCAL | Reserved | ABORT | Reserved |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [16]    | DPRT1       | <p><b>Disable Port 1</b><br/> This bit controls if the connection between USB host controller and transceiver of port 1 is disabled. If the connection is disabled, the USB host controller will not recognize any event of USB bus.</p> <p>Set this bit high, the transceiver of port 1 will also be forced into the standby mode no matter what USB host controller operation is.</p> <p>0 = The connection between USB host controller and transceiver of port 1 Enabled.<br/> 1 = The connection between USB host controller and transceiver of port 1 Disabled and the transceiver of port 1 will also be forced into the standby mode.</p> |
| [15:4]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [3]     | OCAL        | <p><b>over Current Active Low</b><br/> This bit controls the polarity of over current flag from external power IC.<br/> 0 = Over current flag is high active.<br/> 1 = Over current flag is low active.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [2]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [1]     | ABORT       | <p><b>AHB Bus ERROR Response</b><br/> This bit indicates there is an ERROR response received in AHB bus.<br/> 0 = No ERROR response received.<br/> 1 = ERROR response received.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [0]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**EHCI Version Number Register (EHCVNR)**

| Register | Offset          | R/W | Description                  | Reset Value |
|----------|-----------------|-----|------------------------------|-------------|
| EHCVNR   | HSUSBH_BA+0x000 | R   | EHCI Version Number Register | 0x0095_0020 |



| Bits    | Description     |                                                                                                                                                                                                                                                                                                      |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>VERSION</b>  | <b>Host Controller Interface Version Number</b><br>This is a two-byte register containing a BCD encoding of the EHCI revision number supported by this host controller. The most significant byte of this register represents a major revision and the least significant byte is the minor revision. |
| [15:8]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                            |
| [7:0]   | <b>CRLEN</b>    | <b>Capability Registers Length</b><br>This register is used as an offset to add to register base to find the beginning of the Operational Register Space.                                                                                                                                            |

EHCI Structural Parameters Register (EHCSPR)

| Register | Offset          | R/W | Description                         |  |  |  | Reset Value |
|----------|-----------------|-----|-------------------------------------|--|--|--|-------------|
| EHCSPR   | HSUSBH_BA+0x004 | R   | EHCI Structural Parameters Register |  |  |  | 0x0000_0012 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [15:12] | <b>N_CC</b>     | <p><b>Number of Companion Controller</b></p> <p>This field indicates the number of companion controllers associated with this USB 2.0 host controller.</p> <p>A zero in this field indicates there are no companion host controllers. Port-ownership hand-off is not supported. Only high-speed devices are supported on the host controller root ports.</p> <p>A value larger than zero in this field indicates there are companion USB 1.1 host controller(s). Port-ownership hand-offs are supported. High, Full- and Low-speed devices are supported on the host controller root ports.</p>                                                                                                                                             |
| [11:8]  | <b>N_PCC</b>    | <p><b>Number of Ports Per Companion Controller</b></p> <p>This field indicates the number of ports supported per companion host controller. It is used to indicate the port routing configuration to system software.</p> <p>For example, if N_PORTS has a value of 6 and N_CC has a value of 2 then N_PCC could have a value of 3. The convention is that the first N_PCC ports are assumed to be routed to companion controller 1, the next N_PCC ports to companion controller 2, etc. In the previous example, the N_PCC could have been 4, where the first 4 are routed to companion controller 1 and the last two are routed to companion controller 2.</p> <p>The number in this field must be consistent with N_PORTS and N_CC.</p> |
| [7:5]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4]     | <b>PPC</b>      | <p><b>Port Power Control</b></p> <p>This field indicates whether the host controller implementation includes port power control. A one in this bit indicates the ports have port power switches. A zero in this bit indicates the port do not have port power switches. The value of this field affects the functionality of the Port Power field in each port status and control register.</p>                                                                                                                                                                                                                                                                                                                                             |
| [3:0]   | <b>N_PORTS</b>  | <p><b>Number of Physical Downstream Ports</b></p> <p>This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register Space (see Table 2-8). Valid values are in the range of 1H to FH.</p> <p>A zero in this field is undefined.</p>                                                                                                                                                                                                                                                                                                                                                               |

**EHCI Capability Parameters Register (EHCCPR)**

| Register | Offset          | R/W | Description                         |  |  |  | Reset Value |
|----------|-----------------|-----|-------------------------------------|--|--|--|-------------|
| EHCCPR   | HSUSBH_BA+0x008 | R   | EHCI Capability Parameters 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    |
| EECP     |    |    |    |          |      |      |      |
| 7        | 6  | 5  | 4  | 3        | 2    | 1    | 0    |
| IST      |    |    |    | Reserved | ASPC | PFLF | AC64 |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                         |
| [15:8]  | EECP        | <b>EHCI Extended Capabilities Pointer (EECP)</b><br>0 = No extended capabilities are implemented.                                                                                                                                                                                                                                                                                                                 |
| [7:4]   | IST         | <b>Isochronous Scheduling Threshold</b><br>This field indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule.<br>When bit [7] is zero, the value of the least significant 3 bits indicates the number of micro-frames a host controller can hold a set of isochronous data structures (one or more) before flushing the state. |
| [3]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                         |
| [2]     | ASPC        | <b>Asynchronous Schedule Park Capability</b><br>0 = This EHCI host controller doesn't support park feature of high-speed queue heads in the Asynchronous Schedule.                                                                                                                                                                                                                                                |
| [1]     | PFLF        | <b>Programmable Frame List Flag</b><br>0 = System software must use a frame list length of 1024 elements with this EHCI host controller.                                                                                                                                                                                                                                                                          |
| [0]     | AC64        | <b>64-bit Addressing Capability</b><br>0 = Data structure using 32-bit address memory pointers.                                                                                                                                                                                                                                                                                                                   |

USB Command Register (UCMDR)

| Register | Offset          | R/W | Description          |  |  |  | Reset Value |
|----------|-----------------|-----|----------------------|--|--|--|-------------|
| UCMDR    | HSUSBH_BA+0x020 | R/W | USB Command Register |  |  |  | 0x0008_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [23:16] | ITC         | <p><b>Interrupt Threshold Control (R/W)</b></p> <p>This field is used by system software to select the maximum rate at which the host controller will issue interrupts. The only valid values are defined below. If software writes an invalid value to this register, the results are undefined. Value Maximum Interrupt Interval</p> <p>0x00 = Reserved.<br/>     0x01 = 1 micro-frame.<br/>     0x02 = 2 micro-frames.<br/>     0x04 = 4 micro-frames.<br/>     0x08 = 8 micro-frames (default, equates to 1 ms).<br/>     0x10 = 16 micro-frames (2 ms).<br/>     0x20 = 32 micro-frames (4 ms).<br/>     0x40 = 64 micro-frames (8 ms).<br/>     Any other value in this register yields undefined results.<br/>     Software modifications to this bit while HCHalted bit is equal to zero results in undefined behavior.</p>                                                                                   |
| [15:7]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [6]     | IAAD        | <p><b>Interrupt on Asynchronous Advance Doorbell (R/W)</b></p> <p>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell.</p> <p>When the host controller has evicted all appropriate cached schedule state, it sets the Interrupt on Asynchronous Advance status bit in the USBSTS register. If the Interrupt on Asynchronous Advance Enable bit in the USBINTR register is a one then the host controller will assert an interrupt at the next interrupt threshold.</p> <p>The host controller sets this bit to a zero after it has set the Interrupt on Asynchronous Advance status bit in the USBSTS register to a one.</p> <p>Software should not write a one to this bit when the asynchronous schedule is disabled. Doing so will yield undefined results.</p> |

|       |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5]   | <b>ASEN</b>  | <b>Asynchronous Schedule Enable (R/W)</b><br>This bit controls whether the host controller skips processing the Asynchronous Schedule.<br>Values mean:<br>0 = Do not process the Asynchronous Schedule.<br>1 = Use the ASYNCLISTADDR register to access the Asynchronous Schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [4]   | <b>PSEN</b>  | <b>Periodic Schedule Enable (R/W)</b><br>This bit controls whether the host controller skips processing the Periodic Schedule.<br>Values mean:<br>0 = Do not process the Periodic Schedule.<br>1 = Use the PERIODICLISTBASE register to access the Periodic Schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [3:2] | <b>FLSZ</b>  | <b>Frame List Size (R/W or RO)</b><br>This field is R/W only if Programmable Frame List Flag in the HCCPARAMS registers is set to a one. This field specifies the size of the frame list. The size the frame list controls which bits in the Frame Index Register should be used for the Frame List Current index.<br>Values mean:<br>00 = 1024 elements (4096 bytes) Default value.<br>01 = 512 elements (2048 bytes).<br>10 = 256 elements (1024 bytes) – for resource-constrained environment.<br>11 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [1]   | <b>HCRST</b> | <b>Host Controller Reset (HCRESET) (R/W)</b><br>This control bit is used by software to reset the host controller. The effects of this on Root Hub registers are similar to a Chip Hardware Reset.<br>When software writes a one to this bit, the Host Controller resets its internal pipelines, timers, counters, state machines, etc. to their initial value. Any transaction currently in progress on USB is immediately terminated. A USB reset is not driven on downstream ports.<br>All operational registers, including port registers and port state machines are set to their initial values. Port ownership reverts to the companion host controller(s), with the side effects. Software must reinitialize the host controller in order to return the host controller to an operational state.<br>This bit is set to zero by the Host Controller when the reset process is complete. Software cannot terminate the reset process early by writing a zero to this register.<br>Software should not set this bit to a one when the HC Halted bit in the USBSTS register is a zero. Attempting to reset an actively running host controller will result in undefined behavior. |
| [0]   | <b>RUN</b>   | <b>Run/Stop (R/W)</b><br>When set to a 1, the Host Controller proceeds with execution of the schedule. The Host Controller continues execution as long as this bit is set to a 1. When this bit is set to 0, the Host Controller completes the current and any actively pipelined transactions on the USB and then halts. The Host Controller must halt within 16 micro-frames after software clears the Run bit. The HC Halted bit in the status register indicates when the Host Controller has finished its pending pipelined transactions and has entered the stopped state.<br>Software must not write a one to this field unless the host controller is in the Halted state (i.e. HC Halted in the USBSTS register is a one). Doing so will yield undefined results.<br>0 = Stop.<br>1 = Run.                                                                                                                                                                                                                                                                                                                                                                                   |

**USB Status Register (USTSR)**

| Register | Offset          | R/W | Description         |  |  |  | Reset Value |
|----------|-----------------|-----|---------------------|--|--|--|-------------|
| USTSR    | HSUSBH_BA+0x024 | R/W | USB Status Register |  |  |  | 0x0000_1000 |

|          |     |       |          |          |     |         |        |
|----------|-----|-------|----------|----------|-----|---------|--------|
| 31       | 30  | 29    | 28       | 27       | 26  | 25      | 24     |
| Reserved |     |       |          |          |     |         |        |
| 23       | 22  | 21    | 20       | 19       | 18  | 17      | 16     |
| Reserved |     |       |          |          |     |         |        |
| 15       | 14  | 13    | 12       | 11       | 10  | 9       | 8      |
| ASS      | PSS | RECLA | HCHalted | Reserved |     |         |        |
| 7        | 6   | 5     | 4        | 3        | 2   | 1       | 0      |
| Reserved |     | IAA   | HSERR    | FLR      | PCD | UERRINT | USBINT |

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [15]    | <b>ASS</b>      | <b>Asynchronous Schedule Status (Read Only)</b><br>The bit reports the current real status of the Asynchronous Schedule. If this bit is a zero then the status of them Asynchronous Schedule is disabled. If this bit is a one then the status of the Asynchronous Schedule is enabled. The Host Controller is not required to immediately disable or enable the Asynchronous Schedule when software transitions the Asynchronous Schedule Enable bit in the USBCMD register. When this bit and the Asynchronous Schedule Enable bit are the same value, the Asynchronous Schedule is either enabled (1) or disabled (0). |
| [14]    | <b>PSS</b>      | <b>Periodic Schedule Status (Read Only)</b><br>The bit reports the current real status of the Periodic Schedule. If this bit is a zero then the status of the Periodic Schedule is disabled. If this bit is a one then the status of the Periodic Schedule is enabled. The Host Controller is not required to immediately disable or enable the Periodic Schedule when software transitions the Periodic Schedule Enable bit in the USBCMD register. When this bit and the Periodic Schedule Enable bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0).                                  |
| [13]    | <b>RECLA</b>    | <b>Reclamation (Read Only)</b><br>This is a read-only status bit, which is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [12]    | <b>HCHalted</b> | <b>HCHalted (Read Only)</b><br>This bit is a zero whenever the Run/Stop bit is a one. The Host Controller sets this bit to one after it has stopped executing as a result of the Run/Stop bit being set to 0, either by software or by the Host Controller hardware (e.g. internal error).                                                                                                                                                                                                                                                                                                                                |
| [11:6]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [5]     | <b>IAA</b>      | <b>Interrupt on Asynchronous Advance (R/WC)</b><br>System software can force the host controller to issue an interrupt the next time the host controller advances the asynchronous schedule by writing a one to the Interrupt on Asynchronous Advance Doorbell bit in the USBCMD register. This status bit indicates the assertion of that interrupt source.                                                                                                                                                                                                                                                              |
| [4]     | <b>HSERR</b>    | <b>Host System Error (R/WC)</b><br>The Host Controller sets this bit to 1 when a serious error occurs during a host system access involving the Host Controller module.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|     |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3] | <b>FLR</b>     | <b>Frame List Rollover (R/WC)</b><br>The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size (as programmed in the Frame List Size field of the USBCMD register) is 1024, the Frame Index Register rolls over every time FRINDEX[13] toggles. Similarly, if the size is 512, the Host Controller sets this bit to a one every time FRINDEX[12] toggles.                                                                                                                                                                                                                                                                                                                                    |
| [2] | <b>PCD</b>     | <b>Port Change Detect (R/WC)</b><br>The Host Controller sets this bit to a one when any port for which the Port Owner bit is set to zero has a change bit transition from a zero to a one or a Force Port Resume bit transition from a zero to a one as a result of a J-K transition detected on a suspended port. This bit will also be set as a result of the Connect Status Change being set to a one after system software has relinquished ownership of a connected port by writing a one to a port's Port Owner bit.<br><br>This bit is allowed to be maintained in the Auxiliary power well. Alternatively, it is also acceptable that on a D3 to D0 transition of the EHCI HC device, this bit is loaded with the OR of all of the PORTSC change bits (including: Force port resume, over-current change, enable/disable change and connect status change). |
| [1] | <b>UERRINT</b> | <b>USB Error Interrupt (USBERRINT) (R/WC)</b><br>The Host Controller sets this bit to 1 when completion of a USB transaction results in an error condition (e.g., error counter underflow). If the TD on which the error interrupt occurred also had its IOC bit set, both this bit and USBINT bit are set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0] | <b>USBINT</b>  | <b>USB Interrupt (USBINT) (R/WC)</b><br>The Host Controller sets this bit to 1 on the completion of a USB transaction, which results in the retirement of a Transfer Descriptor that had its IOC bit set.<br><br>The Host Controller also sets this bit to 1 when a short packet is detected (actual number of bytes received was less than the expected number of bytes).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

USB Interrupt Enable Register (UIENR)

| Register | Offset          | R/W | Description                   |  |  |  | Reset Value |
|----------|-----------------|-----|-------------------------------|--|--|--|-------------|
| UIENR    | HSUSBH_BA+0x028 | R/W | USB Interrupt Enable Register |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [5]    | IAAEN       | <p><b>Interrupt on Asynchronous Advance Enable or Disable Bit</b></p> <p>When this bit is a one, and the Interrupt on Asynchronous Advance bit in the USBSTS register is a one, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the Interrupt on Asynchronous Advance bit.</p> <p>0 = Interrupt on Asynchronous Advance Disabled.<br/>1 = Interrupt on Asynchronous Advance Enabled.</p> |
| [4]    | HSERREN     | <p><b>Host System Error Enable or Disable Bit</b></p> <p>When this bit is a one, and the Host System Error Status bit in the USBSTS register is a one, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Host System Error bit.</p> <p>0 = Host System Error interrupt Disabled.<br/>1 = Host System Error interrupt Enabled.</p>                                                                                      |
| [3]    | FLREN       | <p><b>Frame List Rollover Enable or Disable Bit</b></p> <p>When this bit is a one, and the Frame List Rollover bit in the USBSTS register is a one, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Frame List Rollover bit.</p> <p>0 = Frame List Rollover interrupt Disabled.<br/>1 = Frame List Rollover interrupt Enabled.</p>                                                                                   |
| [2]    | PCIEN       | <p><b>Port Change Interrupt Enable or Disable Bit</b></p> <p>When this bit is a one, and the Port Change Detect bit in the USBSTS register is a one, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Port Change Detect bit.</p> <p>0 = Port Change interrupt Disabled.<br/>1 = Port Change interrupt Enabled.</p>                                                                                                   |

|     |                |                                                                                                                                                                                                                                                                                                                                                                |
|-----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | <b>UERRIEN</b> | <b>USB Error Interrupt Enable or Disable Bit</b><br>When this bit is a one, and the USBERRINT bit in the USBSTS register is a one, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the USBERRINT bit.<br>0 = USB Error interrupt Disabled.<br>1 = USB Error interrupt Enabled. |
| [0] | <b>USBIEN</b>  | <b>USB Interrupt Enable or Disable Bit</b><br>When this bit is a one, and the USBINT bit in the USBSTS register is a one, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the USBINT bit.<br>0 = USB interrupt Disabled.<br>1 = USB interrupt Enabled.                         |

USB Frame Index Register (UFINDR)

| Register | Offset          | R/W | Description              | Reset Value |
|----------|-----------------|-----|--------------------------|-------------|
| UFINDR   | HSUSBH_BA+0x02C | R/W | USB Frame Index 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 |    | FI |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| FI       |    |    |    |    |    |    |    |

| Bits              | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
|-------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------|---|-----|------|----|-----|-----|----|-----|-----|----|-----|----------|--|
| [31:14]           | Reserved        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| [13:0]            | FI              | <p><b>Frame Index</b><br/> The value in this register increment at the end of each time frame (e.g. micro-frame). Bits [N:3] are used for the Frame List current index. This means that each location of the frame list is accessed 8 times (frames or micro-frames) before moving to the next index. The following illustrates values of N based on the value of the Frame List Size field in the USBCMD register.</p> <table> <thead> <tr> <th>FLSZ (UCMDR[3:2])</th> <th>Number Elements</th> <th>N</th> </tr> </thead> <tbody> <tr> <td>0x0</td> <td>1024</td> <td>12</td> </tr> <tr> <td>0x1</td> <td>512</td> <td>11</td> </tr> <tr> <td>0x2</td> <td>256</td> <td>10</td> </tr> <tr> <td>0x3</td> <td>Reserved</td> <td></td> </tr> </tbody> </table> | FLSZ (UCMDR[3:2]) | Number Elements | N | 0x0 | 1024 | 12 | 0x1 | 512 | 11 | 0x2 | 256 | 10 | 0x3 | Reserved |  |
| FLSZ (UCMDR[3:2]) | Number Elements | N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 0x0               | 1024            | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 0x1               | 512             | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 0x2               | 256             | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 0x3               | Reserved        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |

USB Periodic Frame List Base Address Register (UPFLBAR)

| Register | Offset          | R/W | Description                                   | Reset Value |
|----------|-----------------|-----|-----------------------------------------------|-------------|
| UPFLBAR  | HSUSBH_BA+0x034 | R/W | USB Periodic Frame List Base Address Register | 0x0000_0000 |

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

| Bits    | Description     |                                                                                               |
|---------|-----------------|-----------------------------------------------------------------------------------------------|
| [31:12] | <b>BADDR</b>    | <b>Base Address</b><br>These bits correspond to memory address signals [31:12], respectively. |
| [11:0]  | <b>Reserved</b> | Reserved.                                                                                     |

USB Current Asynchronous List Address Register (UCALAR)

| Register | Offset          | R/W | Description                                    | Reset Value |
|----------|-----------------|-----|------------------------------------------------|-------------|
| UCALAR   | HSUSBH_BA+0x038 | R/W | USB Current Asynchronous List Address Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                         |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | LPL         | <b>Link Pointer Low (LPL)</b><br>These bits correspond to memory address signals [31:5], respectively. This field may only reference a Queue Head (QH). |
| [4:0]  | Reserved    | Reserved.                                                                                                                                               |

USB Asynchronous Schedule Sleep Timer Register (UASSTR)

| Register | Offset          | R/W | Description                                    |  |  |  | Reset Value |
|----------|-----------------|-----|------------------------------------------------|--|--|--|-------------|
| UASSTR   | HSUSBH_BA+0x03C | R/W | USB Asynchronous Schedule Sleep Timer Register |  |  |  | 0x0000_0BD6 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [11:0]  | ASSTMR      | <p><b>Asynchronous Schedule Sleep Timer</b></p> <p>This field defines the AsyncSchedSleepTime of EHCI spec.</p> <p>The asynchronous schedule sleep timer is used to control how often the host controller fetches asynchronous schedule list from system memory while the asynchronous schedule is empty.</p> <p>The default value of this timer is 12'hBD6. Because this timer is implemented in UTMI clock (30MHz) domain, the default sleeping time will be about 100us.</p> |

USB Configure Flag Register (UCFGR)

| Register | Offset          | R/W | Description                 | Reset Value |
|----------|-----------------|-----|-----------------------------|-------------|
| UCFGR    | HSUSBH_BA+0x060 | R/W | USB Configure Flag Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]    | CF          | <p><b>Configure Flag (CF)</b></p> <p>Host software sets this bit as the last action in its process of configuring the Host Controller. This bit controls the default port-routing control logic. Bit values and side-effects are listed below.</p> <p>0 = Port routing control logic default-routes each port to an implementation dependent classic host controller.</p> <p>1 = Port routing control logic default-routes all ports to this host controller.</p> |

USB Port Status and Control Register (UPSCR)

| Register | Offset          | R/W | Description                            |  |  |  | Reset Value |
|----------|-----------------|-----|----------------------------------------|--|--|--|-------------|
| UPSCR0   | HSUSBH_BA+0x064 | R/W | USB Port 0 Status and Control Register |  |  |  | 0x0000_2000 |
| UPSCR1   | HSUSBH_BA+0x068 | R/W | USB Port 1 Status and Control Register |  |  |  | 0x0000_2000 |

|          |     |     |     |      |    |          |      |
|----------|-----|-----|-----|------|----|----------|------|
| 31       | 30  | 29  | 28  | 27   | 26 | 25       | 24   |
| Reserved |     |     |     |      |    |          |      |
| 23       | 22  | 21  | 20  | 19   | 18 | 17       | 16   |
| Reserved |     |     |     | PTC  |    |          |      |
| 15       | 14  | 13  | 12  | 11   | 10 | 9        | 8    |
| Reserved |     | PO  | PP  | LSTS |    | Reserved | PRST |
| 7        | 6   | 5   | 4   | 3    | 2  | 1        | 0    |
| SUSPEND  | FPR | OCC | OCA | PEC  | PE | CSC      | CCS  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [19:16] | PTC         | <p><b>Port Test Control (R/W)</b></p> <p>When this field is zero, the port is NOT operating in a test mode. A non-zero value indicates that it is operating in test mode and the specific test mode is indicated by the specific value. The encoding of the test mode bits are (0x6 ~ 0xF are reserved):</p> <ul style="list-style-type: none"> <li>Bits Test Mode</li> <li>0x0 = Test mode not enabled.</li> <li>0x1 = Test J_STATE.</li> <li>0x2 = Test K_STATE.</li> <li>0x3 = Test SE0_NAK.</li> <li>0x4 = Test Packet.</li> <li>0x5 = Test FORCE_ENABLE.</li> </ul>                |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [13]    | PO          | <p><b>Port Owner (R/W)</b></p> <p>This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register makes a 0 to 1 transition. This bit unconditionally goes to 1 whenever the Configured bit is zero.</p> <p>System software uses this field to release ownership of the port to a selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that a companion host controller owns and controls the port.</p> |
| [12]    | PP          | <p><b>Port Power (PP)</b></p> <p>Host controller has port power control switches. This bit represents the Current setting of the switch (0 = off, 1 = on). When power is not available on a port (i.e. PP equals a 0), the port is nonfunctional and will not report attaches, detaches, etc.</p> <p>When an over-current condition is detected on a powered port and PPC is a one, the PP bit in each affected port may be transitioned by the host controller from a 1 to 0 (removing power from the port).</p>                                                                       |

|         |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | <b>Line Status (Read Only)</b><br>These bits reflect the current logical levels of the D+ (bit 11) and D- (bit 10) signal lines. These bits are used for detection of low-speed USB devices prior to the port reset and enable sequence. This field is valid only when the port enable bit is zero and the current connect status bit is set to a one.<br>The encoding of the bits are:<br>Bits[11:10] USB State Interpretation<br>00 = SEO Not Low-speed device, perform EHCI reset.<br>01 = K-state Low-speed device, release ownership of port.<br>10 = J-state Not Low-speed device, perform EHCI reset.<br>11 = Undefined Not Low-speed device, perform EHCI reset.<br>This value of this field is undefined if Port Power is zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [11:10] | LSTS     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [9]     | Reserved | <b>Port Reset (R/W)</b><br>When software writes a one to this bit (from a zero), the bus reset sequence as defined in the USB Specification Revision 2.0 is started. Software writes a zero to this bit to terminate the bus reset sequence. Software must keep this bit at a one long enough to ensure the reset sequence, as specified in the USB Specification Revision 2.0, completes. <b>Note:</b> when software writes this bit to a one, it must also write a zero to the Port Enable bit.<br>Note that when software writes a zero to this bit there may be a delay before the bit status changes to a zero. The bit status will not read as a zero until after the reset has completed. If the port is in high-speed mode after reset is complete, the host controller will automatically enable this port (e.g. set the Port Enable bit to a one). A host controller must terminate the reset and stabilize the state of the port within 2 milliseconds of software transitioning this bit from a one to a zero. For example: if the port detects that the attached device is high-speed during reset, then the host controller must have the port in the enabled state within 2ms of software writing this bit to a zero.<br>The HCHalted bit in the USBSTS register should be a zero before software attempts to use this bit. The host controller may hold Port Reset asserted to a one when the HCHalted bit is a one.<br>This field is zero if Port Power is zero.<br>0 = Port is not in Reset.<br>1 = Port is in Reset. |
| [8]     | PRST     | <b>Suspend (R/W)</b><br>Port Enabled Bit and Suspend bit of this register define the port states as follows:<br>00 = Port Disable.<br>01 = Port Disable.<br>10 = Port Enable.<br>11 = Port Suspend.<br>When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction, if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspended and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.<br>A write of zero to this bit is ignored by the host controller. The host controller will unconditionally set this bit to a zero when:<br>Software sets the Force Port Resume bit to a zero (from a one).<br>Software sets the Port Reset bit to a one (from a zero).<br>If host software sets this bit to a one when the port is not enabled (i.e. Port enabled bit is a zero) the results are undefined.<br>This field is zero if Port Power is zero.<br>0 = Port not in suspend state.<br>1 = Port in suspend state.                                                                                                                                                                                                                                                                                                                  |
| [7]     | SUSPEND  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     | <b>Force Port Resume (R/W)</b><br>This functionality defined for manipulating this bit depends on the value of the Suspend bit. For example, if the port is not suspended (Suspend and Enabled bits are a one) and software transitions this bit to a one, then the effects on the bus are undefined.<br>Software sets this bit to a 1 to drive resume signaling. The Host Controller sets this bit to a 1 if a J-to-K transition is detected while the port is in the Suspend state. When this bit transitions to a one because a J-to-K transition is detected, the Port Change Detect bit in the USBSTS register is also set to a one. If software sets this bit to a one, the host controller must not set the Port Change Detect bit.<br>Note that when the EHCI controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driven on the port as long as this bit remains a one. Software must appropriately time the Resume and set this bit to a zero when the appropriate amount of time has elapsed. Writing a zero (from one) causes the port to return to high-speed mode (forcing the bus below the port into a high-speed idle). This bit will remain a one until the port has switched to the high-speed idle. The host controller must complete this transition within 2 milliseconds of software setting this bit to a zero.<br>This field is zero if Port Power is zero.<br>0 = No resume (K-state) detected/driven on port.<br>1 = Resume detected/driven on port. |
| [6] | FPR | <b>Over-current Change (R/WC)</b><br>1 = This bit gets set to a one when there is a change to Over-current Active. Software clears this bit by writing a one to this bit position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [5] | OCC | <b>Over-current Active (Read Only)</b><br>This bit will automatically transition from a one to a zero when the over current condition is removed.<br>0 = This port does not have an over-current condition.<br>1 = This port currently has an over-current condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [3] | PEC | <b>Port Enable/Disable Change (R/WC)</b><br>For the root hub, this bit gets set to a one only when a port is disabled due to the appropriate conditions existing at the EOF2 point (See Chapter 11 of the USB Specification for the definition of a Port Error). Software clears this bit by writing a 1 to it.<br>This field is zero if Port Power is zero.<br>0 = No change.<br>1 = Port enabled/disabled status has changed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [2] | PE  | <b>Port Enabled/Disabled (R/W)</b><br>Ports can only be enabled by the host controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. The host controller will only set this bit to a one when the reset sequence determines that the attached device is a high-speed device.<br>Ports can be disabled by either a fault condition (disconnect event or other fault condition) or by host software. Note that the bit status does not change until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller and bus events.<br>When the port is disabled (0b) downstream propagation of data is blocked on this port, except for reset.<br>This field is zero if Port Power is zero.<br>0 = Port Disabled.<br>1 = Port Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | CSC | <b>Connect Status Change (R/W)</b><br>Indicates a change has occurred in the port's Current Connect Status. The host controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware will be "setting" an already-set bit (i.e., the bit will remain set). Software sets this bit to 0 by writing a 1 to it.<br>This field is zero if Port Power is zero.<br>0 = No change.<br>1 = Change in Current Connect Status. |
| [0] | CCS | <b>Current Connect Status (Ready Only)</b><br>This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change bit (Bit 1) to be set.<br>This field is zero if Port Power is zero.<br>0 = No device is present.<br>1 = Device is present on port.                                                                                                                                                                                                                                                                                                             |

USB PHY 0 Control Register (USBPCR0)

| Register | Offset          | R/W | Description                |  |  |  | Reset Value |
|----------|-----------------|-----|----------------------------|--|--|--|-------------|
| USBPCR0  | HSUSBH_BA+0x0C4 | R/W | USB PHY 0 Control Register |  |  |  | 0x0000_0060 |

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

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [11]    | <b>CLKVALID</b> | <p><b>UTMI Clock Valid</b></p> <p>This bit is a flag to indicate if the UTMI clock from USB 2.0 PHY is ready. S/W program must prevent to write other control registers before this UTMI clock valid flag is active.</p> <p>0 = UTMI clock is not valid.<br/>1 = UTMI clock is valid.</p>                                                                                                                                                                                 |
| [10:9]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [8]     | <b>SUSPEND</b>  | <p><b>Suspend Assertion</b></p> <p>This bit controls the suspend mode of USB PHY 0.</p> <p>While PHY was suspended, all circuits of PHY were powered down and outputs are tri-state.</p> <p>This bit is 1'b0 in default. This means the USB PHY 0 is suspended in default. It is necessary to set this bit 1'b1 to make USB PHY 0 leave suspend mode before doing configuration of USB host.</p> <p>0 = USB PHY 0 was suspended.<br/>1 = USB PHY 0 was not suspended.</p> |
| [7:0]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

USB PHY 1 Control Register (USBPCR1)

| Register | Offset          | R/W | Description                | Reset Value |
|----------|-----------------|-----|----------------------------|-------------|
| USBPCR1  | HSUSBH_BA+0x0C8 | R/W | USB PHY 1 Control Register | 0x0000_0020 |

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

| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [8]    | <b>SUSPEND</b>  | <p><b>Suspend Assertion</b><br/> This bit controls the suspend mode of USB PHY 1.<br/> While PHY was suspended, all circuits of PHY were powered down and outputs are tri-state.</p> <p>This bit is 1'b0 in default. This means the USB PHY 0 is suspended in default. It is necessary to set this bit 1'b1 to make USB PHY 0 leave suspend mode before doing configuration of USB host.</p> <p>0 = USB PHY 1 was suspended.<br/> 1 = USB PHY 1 was not suspended.</p> |
| [7:0]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## 6.33 USB On-The-Go (OTG)

### 6.33.1 Overview

The OTG controller interfaces to USB PHY and USB controllers which consist of a USB 1.1 host controller and a USB 2.0 FS device controller. The OTG controller supports HNP and SRP protocols defined in the “On-The-Go and Embedded Host Supplement to the USB 2.0 Revision 2.0 Specification”.

USB frame, including USB host, USB device, and OTG controller, can be configured as Host-only, Device-only, ID-dependent or OTG Device mode defined in USBROLE (SYS\_USBPHY[1:0]). In Host-only mode, USB frame acts as USB host. USB frame can support both full-speed and low-speed transfer. In Device-only mode, USB frame acts as USB device. USB frame only supports full-speed transfer. In ID-dependent mode, USB frame can be USB Host or USB device depending on USB\_ID pin state. In OTG device mode, the role of USB frame depends on the definition of OTG specification. USB frame only supports full-speed transfer when OTG device acts as a peripheral.

### 6.33.2 Features

- Built-in USB PHY
- Configurable to operate as:
  - Host-only
  - Device-only
  - ID-dependent: The role of USB frame is only dependent on USB\_ID pin value--as USB Host (USB\_ID pin is low) or USB Device (USB\_ID pin is high). Not support HNP or SRP protocol.
  - OTG device: dependent on USB\_ID pin status to be A-device (USB\_ID pin is low) or B-device (USB\_ID pin is high). Support HNP and SRP protocols.

### 6.33.3 Block Diagram



Figure 6.33-1 USB OTG Block Diagram

### 6.33.4 Basic Configuration

The OTG peripheral clock can be enabled by OTGCKEN (CLK\_APBCLK0[26]). The role of USB frame is determined by USBROLE (SYS\_USBPHY[1:0]). The internal USB 3.3V LDO can be enabled by LDO33EN (SYS\_USBPHY[8]). These two configurations are write-protection bits. Before writing to these bits, user must disable the register protection function. Refer to the description of SYS\_REGLCTL register for details. USB\_VBUS\_EN and USB\_VBUS\_ST pin functions are configured in SYS\_GPA\_MFPL or SYS\_GPC\_MFPL registers.

### 6.33.5 Functional Description

The role of USB frame depends on the setting of USBROLE (SYS\_USBPHY[1:0]) and USB\_ID pin status. The USBROLE configuration has precedence over USB\_ID pin status. User can configure the OTG controller to USB Host mode, USB Device mode, ID dependent mode or OTG Device mode. In USB Host mode, the host controller will interact with USB PHY directly. In USB Device mode, the device controller will interact with USB PHY directly. In these cases, the OTG controller is used simply as a multiplexer. In ID dependent mode, USB\_ID pin status will decide USB frame to act as USB host or USB device. If the USB\_ID pin is FALSE state (low level), USB frame will act as USB host. If the USB\_ID pin is TRUE state (high level), USB frame will act as USB device. In OTG Device mode, the OTG controller will handle OTG HNP and SRP protocols. If the USB\_ID pin is FALSE state (low level), the OTG controller will act as an OTG A-device. If the USB\_ID pin is TRUE state (high level), the OTG controller will act as an OTG B-device.

#### 6.33.5.1 The Role of USB Frame

##### USB Device Mode

When USBROLE (SYS\_USBPHY[1:0]) is set to 0, USB frame acts as USB device. The USB host function is not available.



Figure 6.33-2 USB Device Mode

##### USB Host Mode

When USBROLE (SYS\_USBPHY[1:0]) is set to 1, USB frame acts as USB host. USB device function is not available.



Figure 6.33-3 USB Host Mode

### ID Dependent Mode

When USBROLE (SYS\_USBPHY[1:0]) is set to 2, the role of USB frame depends on USB\_ID pin status. The ID detection function can be enabled by set IDDETEN (OTG\_PHYCTL[1]) to 1. The USB\_ID pin status reflects on IDSTS (OTG\_STATUS[1]). When USB frame acts as USB host (USB\_ID pin is low level), the block diagram is the same as USB Host mode. When USB frame acts as USB device (USB\_ID pin is high level), the block diagram is the same as USB Device mode.

### OTG Device Mode

When USBROLE (SYS\_USBPHY[1:0]) is set to 3, the role of USB frame depends on USB\_ID pin status. The ID detection function can be enabled by set IDDETEN (OTG\_PHYCTL[1]) to 1. The USB\_ID pin status reflects on IDSTS (OTG\_STATUS[1]). When USB\_ID pin status is low level, the OTG controller acts as OTG A-device. When USB\_ID pin status is high level, the OTG controller acts as OTG B-device. Please refer to OTG specification to get detail behavior of A-device and B-device.

#### 6.33.5.2 Session Request Protocol (SRP)

When the USB frame is configured as OTG Device mode, OTG controller supports SRP to conserve power. Refer to OTG specification for details of SRP.

#### A-Device Session Request Protocol

1. A-device turns off USB bus power to conserve power. B-device recognizes such condition by checking VBUS status.
2. B-device requests A-device to supply USB bus power by Data line pulsing when B-device wants to connect to A-device.
3. A-device recognizes USB bus power request through checking SRPDETIF (OTG\_INTSTS[13]).
4. A-device starts to drive VBUS by setting BUSREG (OTG\_CTL[1]) to 1 once SRPDETIF (OTG\_INTSTS[13]) is set to 1 by hardware. If VBUS reaches valid level in specific time interval and B-device is connected, A-device will become USB host, HOSTIF (OTG\_INTSTS[7]) will be set to 1. If VBUS cannot reach valid level in specific time interval, it means overcurrent condition occurs.

Then VBUS error bit, VBEIF (OTG\_IS[1]), will be set to 1.

#### B-device Session Request Protocol

1. A-device turns off USB bus power to conserve power. B-device recognizes such condition by checking VBUSVLD (OTG\_STATUS[5]).
2. B-device can request A-device to supply USB bus power by setting BUSREQ(OTG\_CTL[1]) to 1.
3. B-device will generate data line pulsing as defined in OTG specification.
4. A-device will start to drive VBUS after detecting data line pulsing and B-device can recognize such condition by checking VBUSVLD (OTG\_STATUS[5]). If A-device drives VBUS to valid level in specific time interval, B-device becomes USB peripheral, PDEVIF (OTG\_INTSTS[6]) will be set to 1. If A-device does not drive VBUS to valid level in specific time interval, SRP failure flag, SRPFIF (OTG\_INTSTS[2]), will be set to 1 and B-device will go to idle state defined in OTG specification.

#### 6.33.5.3 Host Negotiation Protocol (HNP)

When the USB frame is configured as OTG Device mode, the host function can be transferred between two directly connected OTG device without changing the cable connection. Refer to OTG specification for details of HNP.

#### A-device Host Negotiation Protocol

1. A-Host defined in OTG specification sends SetFeature b\_hnp\_enable command to enable B-device HNP capability. B-device responses ACK to indicate B-device supports HNP. User needs to set HNPREQEN (OTG\_CTL[2]) to 1 to enable HNP protocol.
2. A-Host goes to a\_suspend state by setting BUSREQ (OTG\_CTL[1]) to 0 and put USB bus into J-state (USB\_D+ high and USB\_D- low) when A-Host has finished all desired operations.
3. A-Host becomes A-Peripheral if A-Host detects B-peripheral dis-connected by checking USB\_D+ and USB\_D- low in specific time interval. If A-Host cannot detect B-Peripheral dis-connected in specific time interval, A-Host will back to idle state.

#### B-device Host Negotiation Protocol

1. After B-Peripheral receives SetFeature b\_hnp\_enable command successfully, user enables B-peripheral HNP function by setting HNPREQEN (OTG\_CTL[2]) to 1.
2. User sets BUSREG (OTG\_CTL[1]) to 1 after detecting USB bus in J-state(USB\_D+ high and USB\_D- low). Then USB\_D+ pull high resistor will be removed to cause USB disconnect state (USB\_D+ low and USB\_D- low).
3. If B-device detects A-device is connected (USB\_D+ high) in specific time interval, B-device will become B-Host. If B-device cannot detect A-device is connected (USB\_D+ high) in specific time interval, HNP failure flag, HNPFIIF (OTG\_INTSTS[3]), will be set to 1.

### 6.33.6 Register Map

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

| Register                    | Offset      | R/W | Description                   | Reset Value |
|-----------------------------|-------------|-----|-------------------------------|-------------|
| <b>OTG Base Address:</b>    |             |     |                               |             |
| <b>OTG_BA = 0x4004_D000</b> |             |     |                               |             |
| <b>OTG_CTL</b>              | OTG_BA+0x00 | R/W | OTG Control Register          | 0x0000_0000 |
| <b>OTG_PHYCTL</b>           | OTG_BA+0x04 | R/W | OTG PHY Control Register      | 0x0000_0000 |
| <b>OTG_INTEN</b>            | OTG_BA+0x08 | R/W | OTG Interrupt Enable Register | 0x0000_0000 |
| <b>OTG_INTSTS</b>           | OTG_BA+0x0C | R/W | OTG Interrupt Status Register | 0x0000_0000 |
| <b>OTG_STATUS</b>           | OTG_BA+0x10 | R   | OTG Status Register           | 0x0000_0006 |

### 6.33.7 Register Description

#### OTG Control Register (OTG\_CTL)

| Register | Offset      | R/W | Description          |  |  | Reset Value |
|----------|-------------|-----|----------------------|--|--|-------------|
| OTG_CTL  | OTG_BA+0x00 | R/W | OTG Control Register |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [5]    | WKEN        | <b>OTG ID Pin Wake-up Enable Bit</b><br>0 = OTG ID pin status change wake-up function Disabled.<br>1 = OTG ID pin status change wake-up function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4]    | OTGEN       | <b>OTG Function Enable Bit</b><br>User needs to set this bit to enable OTG function while USB frame configured as OTG device. When USB frame not configured as OTG device, this bit is must be low.<br>0= OTG function Disabled.<br>1 = OTG function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [2]    | HNPREQEN    | <b>OTG HNP Request Enable Bit</b><br>When USB frame as A-device, set this bit when A-device allows to process HNP protocol—A-device changes role from Host to Peripheral. This bit will be cleared when OTG state changes from a_suspend to a_peripheral or goes back to a_idle state.<br>When USB frame as B-device, set this bit after the OTG A-device successfully sends a SetFeature (b_hnp_enable) command to the OTG B-device to start role change—B-device changes role from Peripheral to Host. This bit will be cleared when OTG state changes from b_peripheral to b_wait_acon or goes back to b_idle state.<br>0 = HNP request Disabled.<br>1 = HNP request Enabled (A-device can change role from Host to Peripheral or B-device can change role from Peripheral to Host).<br><b>Note:</b> Refer to OTG specification to get a_suspend, a_peripheral, a_idle and b_idle state. |
| [1]    | BUSREQ      | <b>OTG Bus Request</b><br>If OTG A-device wants to do data transfers via USB bus, setting this bit will drive VBUS high to detect USB device connection. If user won't use the bus any more, clearing this bit will drop VBUS to save power. This bit will be cleared when A-device goes to A_wait_vfall state. This bit will be also cleared if VBUSDROP (OTG_CTL[0]) bit is set or IDSTS (OTG_STATUS[1]) changed.<br>If user of an OTG-B Device wants to request VBUS, setting this bit will run SRP protocol.                                                                                                                                                                                                                                                                                                                                                                            |

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <p>This bit will be cleared if SRP failure (OTG A-device does not provide VBUS after B-device issues ARP in specified interval, defined in OTG specification). This bit will be also cleared if VBUSDROP (OTG_CTL[0]) bit is set IDSTS (OTG_STATUS[1]) changed.</p> <p>0 = Do not launch VBUS in OTG A-device or not request SRP in OTG B-device.<br/>1 = Launch VBUS in OTG A-device or request SRP in OTG B-device.</p> |
| [0]  | <p><b>Drop VBUS Control</b></p> <p>If user application running on this OTG A-device wants to conserve power, set this bit to drop VBUS. BUSREQ (OTG_CTL[1]) will be also cleared no matter A-device or B-device.</p> <p>0 = Do not drop the VBUS.<br/>1 = Drop the VBUS.</p>                                                                                                                                              |

OTG PHY Control Register (OTG\_PHYCTL)

| Register   | Offset      | R/W | Description              |  |  | Reset Value |
|------------|-------------|-----|--------------------------|--|--|-------------|
| OTG_PHYCTL | OTG_BA+0x04 | R/W | OTG PHY 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 |    | VBSTSPOL | VBNPOL | Reserved |    | IDDETEN | OTGPHYEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [5]    | VBSTSPOL    | <p><b>Off-chip USB VBUS Power Switch Status Polarity</b><br/> The polarity of off-chip USB VBUS power switch valid signal depends on the selected component. A USB_VBUS_ST pin is used to monitor the valid signal of the off-chip USB VBUS power switch. Set this bit as following according to the polarity of off-chip USB VBUS power switch.<br/> 0 = The polarity of off-chip USB VBUS power switch valid status is high.<br/> 1 = The polarity of off-chip USB VBUS power switch valid status is low.</p>                                                                                   |
| [4]    | VBNPOL      | <p><b>Off-chip USB VBUS Power Switch Enable Polarity</b><br/> The OTG controller will enable off-chip USB VBUS power switch to provide VBUS power when need. A USB_VBUS_EN pin is used to control the off-chip USB VBUS power switch.<br/> The polarity of enabling off-chip USB VBUS power switch (high active or low active) depends on the selected component. Set this bit as following according to the polarity of off-chip USB VBUS power switch.<br/> 0 = The off-chip USB VBUS power switch enable is active high.<br/> 1 = The off-chip USB VBUS power switch enable is active low.</p> |
| [3:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [1]    | IDDETEN     | <p><b>ID Detection Enable Bit</b><br/> 0 = Detect ID pin status Disabled.<br/> 1 = Detect ID pin status Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [0]    | OTGPHYEN    | <p><b>OTG PHY Enable Bit</b><br/> When USB frame is configured as OTG-device or ID-dependent, user needs to set this bit before using OTG function. If device is not configured as OTG-device nor ID-dependent, this bit is "don't care".<br/> 0 = OTG PHY Disabled.<br/> 1 = OTG PHY Enabled.</p>                                                                                                                                                                                                                                                                                                |

OTG Interrupt Enable Register (OTG\_INTEN)

| Register  | Offset      | R/W | Description                   |  |  | Reset Value |
|-----------|-------------|-----|-------------------------------|--|--|-------------|
| OTG_INTEN | OTG_BA+0x08 | R/W | OTG 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 |          | SRPDETIEN | Reserved  | SECHGIEN | VBCHGIEN | AVLDCHGIEN | BVLDCHGIEN |
| 7        | 6        | 5         | 4         | 3        | 2        | 1          | 0          |
| HOSTIEN  | PDEVIEEN | IDCHGIEN  | GOIDLEIEN | HNPFIEN  | SRPFIEN  | VBEIEN     | ROLECHGIEN |

| Bits    | Description |                                                                                                                                                                                                                                                                  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                        |
| [13]    | SRPDETIEN   | <b>SRP Detected Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                                    |
| [12]    | Reserved    | Reserved.                                                                                                                                                                                                                                                        |
| [11]    | SECHGIEN    | <b>SESSEND Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and SESSEND (OTG_STATUS[2]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.             |
| [10]    | VBCHGIEN    | <b>VBUSVLD Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and VBUSVLD (OTG_STATUS[5]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.             |
| [9]     | AVLDCHGIEN  | <b>A-device Session Valid Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and AVLD (OTG_STATUS[4]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |
| [8]     | BVLDCHGIEN  | <b>B-device Session Valid Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and BVLD (OTG_STATUS[3]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |
| [7]     | HOSTIEN     | <b>Act As Host Interrupt Enable Bit</b><br>If this bit is set to 1 and the device is changed as a host, a interrupt will be asserted.                                                                                                                            |

| Bits | Description                                                                                                                                                                                                                                                                                  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 0 = This device as a host interrupt Disabled.<br>1 = This device as a host interrupt Enabled.                                                                                                                                                                                                |
| [6]  | <b>PDEVIEEN</b><br><b>Act As Peripheral Interrupt Enable Bit</b><br>If this bit is set to 1 and the device is changed as a peripheral, a interrupt will be asserted.<br>0 = This device as a peripheral interrupt Disabled.<br>1 = This device as a peripheral interrupt Enabled.            |
| [5]  | <b>IDCHGIEN</b><br><b>IDSTS Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and IDSTS (OTG_STATUS[1]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                 |
| [4]  | <b>GOIDLEIEN</b><br><b>OTG Device Goes to IDLE State Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> Going to idle state means going to a_idle or b_idle state. Please refer to A-device state diagram and B-device state diagram in OTG spec. |
| [3]  | <b>HNPFIEN</b><br><b>HNP Fail Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                                                  |
| [2]  | <b>SRPFIEN</b><br><b>SRP Fail Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                                                  |
| [1]  | <b>VBEIEN</b><br><b>VBUS Error Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> VBUS error means going to a_vbus_err state. Please refer to A-device state diagram in OTG spec.                                                                 |
| [0]  | <b>ROLECHGIEN</b><br><b>Role (Host or Peripheral) Changed Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                      |

OTG Interrupt Status Register (OTG\_INTSTS)

| Register   | Offset      | R/W | Description                   |  |  | Reset Value |
|------------|-------------|-----|-------------------------------|--|--|-------------|
| OTG_INTSTS | OTG_BA+0x0C | R/W | OTG 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 |        | SRPDETIF | Reserved | SECHGIF | VBCHGIF | AVLDCHGIF | BVLDCHGIF |
| 7        | 6      | 5        | 4        | 3       | 2       | 1         | 0         |
| HOSTIF   | PDEVIF | IDCHGIF  | GOIDLEIF | HNPFIF  | SRPFIF  | VBEIF     | ROLECHGIF |

| Bits    | Description |                                                                                                                                                                                                                    |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                          |
| [13]    | SRPDETIF    | <b>SRP Detected Interrupt Status</b><br>0 = SRP not detected.<br>1 = SRP detected.<br><b>Note:</b> Write 1 to clear this status.                                                                                   |
| [12]    | Reserved    | <b>Note:</b>                                                                                                                                                                                                       |
| [11]    | SECHGIF     | <b>SESSEND State Change Interrupt Status</b><br>0 = SESSEND (OTG_STATUS[2]) not toggled.<br>1 = SESSEND (OTG_STATUS[2]) from high to low or from low to high.<br><b>Note:</b> Write 1 to clear this flag.          |
| [10]    | VBCHGIF     | <b>VBUSVLD State Change Interrupt Status</b><br>0 = VBUSVLD (OTG_STATUS[5]) not toggled.<br>1 = VBUSVLD (OTG_STATUS[5]) from high to low or from low to high.<br><b>Note:</b> Write 1 to clear this status.        |
| [9]     | AVLDCHGIF   | <b>A-device Session Valid State Change Interrupt Status</b><br>0 = AVLD (OTG_STATUS[4]) not toggled.<br>1 = AVLD (OTG_STATUS[4]) from high to low or low to high.<br><b>Note:</b> Write 1 to clear this status.    |
| [8]     | BVLDCHGIF   | <b>B-device Session Valid State Change Interrupt Status</b><br>0 = BVLD (OTG_STATUS[3]) is not toggled.<br>1 = BVLD (OTG_STATUS[3]) from high to low or low to high.<br><b>Note:</b> Write 1 to clear this status. |
| [7]     | HOSTIF      | <b>Act As Host Interrupt Status</b><br>0= This device does not act as a host.<br>1 = This device acts as a host.<br><b>Note:</b> Write 1 to clear this flag.                                                       |

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]  | <p><b>PDEVIF</b></p> <p><b>Act As Peripheral Interrupt Status</b><br/>0= This device does not act as a peripheral.<br/>1 = This device acts as a peripheral.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                                                                                                                                                                                                                                                                               |
| [5]  | <p><b>IDCHGIF</b></p> <p><b>ID State Change Interrupt Status</b><br/>0 = IDSTS (OTG_STATUS[1]) not toggled.<br/>1 = IDSTS (OTG_STATUS[1]) from high to low or from low to high.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                                                                                                                                                                                                                                                            |
| [4]  | <p><b>GOIDLEIF</b></p> <p><b>OTG Device Goes to IDLE Interrupt Status</b><br/>Flag is set if the OTG device transfers from non-idle state to idle state. The OTG device will be neither a host nor a peripheral.<br/>0 = OTG device does not go back to idle state (a_idle or b_idle).<br/>1 = OTG device goes back to idle state(a_idle or b_idle).</p> <p><b>Note 1:</b> Going to idle state means going to a_idle or b_idle state. Please refer to OTG specification.</p> <p><b>Note 2:</b> Write 1 to clear this flag.</p> |
| [3]  | <p><b>HNPFIF</b></p> <p><b>HNP Fail Interrupt Status</b><br/>When A-device has granted B-device to be host and USB bus is in SEO (both USB_D+ and USB_D- low) state, this bit will be set when A-device does not connect after specified interval expires.<br/>0 = A-device connects to B-device before specified interval expires.<br/>1 = A-device does not connect to B-device before specified interval expires.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                       |
| [2]  | <p><b>SRPFIF</b></p> <p><b>SRP Fail Interrupt Status</b><br/>After initiating SRP, an OTG B-device will wait for the OTG A-device to drive VBUS high at least TB_SRP_FAIL minimum, defined in OTG specification. This flag is set when the OTG B-device does not get VBUS high after this interval.<br/>0 = OTG B-device gets VBUS high before this interval.<br/>1 = OTG B-device does not get VBUS high before this interval.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                            |
| [1]  | <p><b>VBEIF</b></p> <p><b>VBUS Error Interrupt Status</b><br/>This bit will be set when voltage on VBUS cannot reach a minimum valid threshold 4.4V within a maximum time of 100ms after OTG A-device starting to drive VBUS high.<br/>0 = OTG A-device drives VBUS over threshold voltage before this interval expires.<br/>1 = OTG A-device cannot drive VBUS over threshold voltage before this interval expires.</p> <p><b>Note:</b> Write 1 to clear this flag and recover from the VBUS error state.</p>                 |
| [0]  | <p><b>ROLECHGIF</b></p> <p><b>OTG Role Change Interrupt Status</b><br/>This flag is set when the role of an OTG device changed from a host to a peripheral, or changed from a peripheral to a host while USB_ID pin status does not change.<br/>0 = OTG device role not changed.<br/>1 = OTG device role changed.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                                                                                                                          |

**OTG Functional Status Register (OTG\_STATUS)**

| Register   | Offset      | R/W | Description         |  |  |  | Reset Value |
|------------|-------------|-----|---------------------|--|--|--|-------------|
| OTG_STATUS | OTG_BA+0x10 | R   | OTG Status Register |  |  |  | 0x0000_0006 |

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

| Bits   | Description |                                                                                                                                                                                                |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                      |
| [7]    | ASHOST      | <b>As Host Status</b><br>When OTG acts as Host, this bit is set.<br>0 = OTG not as Host.<br>1 = OTG as Host.                                                                                   |
| [6]    | ASPERI      | <b>As Peripheral Status</b><br>When OTG acts as peripheral, this bit is set.<br>0 = OTG not as peripheral.<br>1 = OTG as peripheral.                                                           |
| [5]    | VBUSVLD     | <b>VBUS Valid Status</b><br>When VBUS is larger than 4.7V, this bit will be set to 1.<br>0 = VBUS is not valid.<br>1 = VBUS is valid.                                                          |
| [4]    | AVLD        | <b>A-device Session Valid Status</b><br>0 = A-device session is not valid.<br>1 = A-device session is valid.                                                                                   |
| [3]    | BVLD        | <b>B-device Session Valid Status</b><br>0 = B-device session is not valid.<br>1 = B-device session is valid.                                                                                   |
| [2]    | SESEND      | <b>Session End Status</b><br>When VBUS voltage is lower than 0.4V, this bit will be set to 1. Session end means no meaningful power on VBUS.<br>0 = Session is not end.<br>1 = Session is end. |
| [1]    | IDSTS       | <b>USB_ID Pin State of Mini-b/Micro-plug</b><br>0 = Mini-A/Micro-A plug is attached.                                                                                                           |

| Bits | Description                                                                                                                                                                                                                                                                                                      |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 1 = Mini-B/Micro-B plug is attached.                                                                                                                                                                                                                                                                             |
| [0]  | <b>OVERCUR</b><br><b>Overcurrent Condition</b><br>The voltage on VBUS cannot reach a minimum VBUS valid threshold, 4.4V minimum, within a maximum time of 100ms after OTG A-device drives VBUS high.<br>0 = OTG A-device drives VBUS successfully.<br>1 = OTG A-device cannot drives VBUS high in this interval. |

## 6.34 High Speed USB On-The-Go (HSOTG)

### 6.34.1 Overview

The HSOTG controller interfaces to USB PHY and USB controllers which consist of a USB 2.0 host controller and a USB 2.0 HS device controller. The OTG controller supports HNP and SRP protocols defined in the “On-The-Go and Embedded Host Supplement to the USB 2.0 Revision 1.3 Specification”.

USB frame, including USB host, USB device, and OTG controller, can be configured as Host-only, Device-only, ID-dependent or OTG Device mode defined in HSUSBROLE (SYS\_USBPHY[17:16]). In Host-only mode, USB frame acts as USB host. USB frame can support high-speed, full-speed and low-speed transfer. In Device-only mode, USB frame acts as USB device. USB frame supports high-speed and full-speed transfer. In ID-dependent mode, USB frame can be USB Host or USB device depends on USB\_ID pin state. In OTG device mode, the role of USB frame depends on the definition of OTG specification. USB frame supports high-speed and full-speed transfer when OTG device acts as a peripheral.

### 6.34.2 Features

- Built in USB PHY
- Configurable to operate as:
  - Host-only
  - Device-only
  - ID-dependent: The role of USB frame is only dependent on USB\_ID pin value--as USB Host (USB\_ID pin is low) or USB Device (USB\_ID pin is high). Not support HNP or SRP protocol.
  - OTG device: dependent on USB\_ID pin status to be A-device (USB\_ID pin is low) or B-device (USB\_ID pin is high). Support HNP and SRP protocols.

### 6.34.3 Block Diagram



Figure 6.34-1 USB OTG Block Diagram

#### 6.34.4 Basic Configuration

- Clock Source Configuration
  - Enable HSOTG clock in HSOTGCKEN(CLK\_AHBCLK[30]).
- Reset Configuration
  - Reset HSOTG in HSOTGRST (SYS\_IPRST2[30]).

The OTG peripheral clock can be enabled by HSOTGCKEN (CLK\_APBCLK0[30]). The role of USB frame is determined by HSUSBROLE (SYS\_USBPHY[17:16]). These two configurations are write-protection bits. Before writing to these bits, user must disable the register protection function. Refer to the description of SYS\_REGLCTL register for details. USB\_VBUS\_EN and USB\_VBUS\_ST pin functions are configured in SYS\_GPA\_MFPL or SYS\_GPC\_MFPL registers.

#### 6.34.5 Functional Description

The role of USB frame depends on the setting of HSUSBROLE (SYS\_USBPHY[17:16]) and USB\_ID pin status. The HSUSBROLE configuration has precedence over USB\_ID pin status. User can configure the OTG controller to USB Host mode, USB Device mode, ID dependent mode or OTG Device mode. In USB Host mode, the host controller will interact with USB PHY directly. In USB Device mode, the device controller will interact with USB PHY directly. In these cases, the OTG controller is used simply as a multiplexer. In ID dependent mode, USB\_ID pin status will decide USB frame to act as USB host or USB device. If the USB\_ID pin is FALSE state (low level), USB frame will act as USB host. If the USB\_ID pin is TRUE state (high level), USB frame will act as USB device. In OTG Device mode, the OTG controller will handle OTG HNP and SRP protocols. If the USB\_ID pin is FALSE state (low level), the OTG controller will act as an OTG A-device. If the USB\_ID pin is TRUE state (high level), the OTG controller will act as an OTG B-device.

##### 6.34.5.1 The Role of USB Frame

###### USB Device Mode

When USBROLE (SYS\_USBPHY[1:0]) is set to 0, USB frame acts as USB device. USB host function is not available.



Figure 6.34-2 USB Device Mode

### USB Host Mode

When HSUSBROLE (SYS\_USBPHY[17:16]) is set to 1, USB frame acts as USB host. USB device function is not available.



Figure 6.34-3 USB Host Mode

### ID Dependent Mode

When HSUSBROLE (SYS\_USBPHY[17:16]) is set to 2, the role of USB frame depends on USB\_ID pin status. The ID detection function can be enabled by set IDDETEN (HSOTG\_PHYCTL[1]) to 1. The USB\_ID pin status reflects on IDSTS (HSOTG\_STATUS[1]). When USB frame acts as USB host (USB\_ID pin is low level), the block diagram is the same as USB Host mode. When USB frame acts as USB device (USB\_ID pin is high level), the block diagram is the same as USB Device mode.

### OTG Device Mode

When HSUSBROLE (SYS\_USBPHY[17:16]) is set to 3, the role of USB frame depends on USB\_ID pin status. The ID detection function can be enabled by set IDDETEN (HSOTG\_PHYCTL[1]) to 1. The USB\_ID pin status reflects on IDSTS (HSOTG\_STATUS[1]). When USB\_ID pin status is low level, the OTG controller acts as OTG A-device. When USB\_ID pin status is high level, the OTG controller acts as OTG B-device. Please refer to OTG specification to get detail behavior of A-device and B-device.

#### 6.34.5.2 Session Request Protocol (SRP)

When the USB frame is configured as OTG Device mode, OTG controller supports SRP to conserve power. Refer to OTG specification for details of SRP.

##### A-Device Session Request Protocol

1. A-device turns off USB bus power to conserve power. B-device recognizes such condition by checking VBUS status.
2. B-device requests A-device to supply USB bus power by Data line pulsing when B-device wants to connect to A-device.
3. A-device recognizes USB bus power request through checking SRPDETIF (HSOTG\_INTSTS[13]).
4. A-device starts to drive VBUS by setting BUSREG (HSOTG\_CTL[1]) to 1 once SRPDETIF (HSOTG\_INTSTS[13]) is set to 1 by hardware. If VBUS reaches valid level in specific time interval and B-device is connected, A-device will become USB host, HOSTIF (HSOTG\_INTSTS[7]) will be set to 1. If VBUS cannot reach valid level in specific time interval, it means overcurrent condition occurs. Then VBUS error bit, VBEIF (HSOTG\_IS[1]), will be set to 1.

##### B-device Session Request Protocol

1. A-device turns off USB bus power to conserve power. B-device recognizes such condition by checking VBUSVLD (HSOTG\_STATUS[5]).
2. B-device can request A-device to supply USB bus power by setting BUSREQ(HSOTG\_CTL[1]) to 1.
3. B-device will generate data line pulsing as defined in OTG specification.
4. A-device will start to drive VBUS after detecting data line pulsing and B-device can recognize such condition by checking VBUSVLD (HSOTG\_STATUS[5]). If A-device drives VBUS to valid level in specific time interval, B-device becomes USB peripheral, PDEVIF (HSOTG\_INTSTS[6]) will be set to 1. If A-device does not drive VBUS to valid level in specific time interval, SRP failure flag, SRPFIF (HSOTG\_INTSTS[2]), will be set to 1 and B-device will go to idle state defined in OTG specification.

#### 6.34.5.3 Host Negotiation Protocol (HNP)

When the USB frame is configured as OTG Device mode, the host function can be transferred between two directly connected OTG device without changing the cable connection. Refer to OTG specification for details of HNP.

##### A-device Host Negotiation Protocol

1. A-Host defined in OTG specification sends SetFeature b\_hnp\_enable command to enable B-device HNP capability. B-device responses ACK to indicate B-device supports HNP. User needs to set HNPREQEN (HSOTG\_CTL[2]) to 1 to enable HNP protocol.
2. A-Host goes to a\_suspend state by setting BUSREQ (HSOTG\_CTL[1]) to 0 and put USB bus

into J-state (USB\_D+ high and USB\_D- low) when A-Host has finished all desired operations.

3. A-Host becomes A-Peripheral if A-Host detects B-peripheral dis-connected by checking USB\_D+ and USB\_D- low in specific time interval. If A-Host cannot detect B-Peripheral dis-connected in specific time interval, A-Host will back to idle state.

#### B-device Host Negotiation Protocol

1. After B-Peripheral receives SetFeature b\_hnp\_enable command successfully, user enables B-peripheral HNP function by setting HNPREQEN (HSOTG\_CTL[2]) to 1.
2. User sets BUSREG (HSOTG\_CTL[1]) to 1 after detecting USB bus in J-state(USB\_D+ high and USB\_D- low). Then USB\_D+ pull high resistor will be removed to cause USB disconnect state (USB\_D+ low and USB\_D- low).
3. If B-device detects A-device is connected (USB\_D+ high) in specific time interval, B-device will become B-Host. If B-device cannot detect A-device is connected (USB\_D+ high) in specific time interval, HNP failure flag, HNPFI (HSOTG\_INTSTS[3]), will be set to 1.

### 6.34.6 Register Map

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

| Register                      | Offset        | R/W | Description                     | Reset Value |
|-------------------------------|---------------|-----|---------------------------------|-------------|
| <b>HSOTG Base Address:</b>    |               |     |                                 |             |
| <b>HSOTG_BA = 0x4004_F000</b> |               |     |                                 |             |
| <b>HSOTG_CTL</b>              | HSOTG_BA+0x00 | R/W | HSOTG Control Register          | 0x0000_0000 |
| <b>HSOTG_PHYCTL</b>           | HSOTG_BA+0x04 | R/W | HSOTG PHY Control Register      | 0x0000_0000 |
| <b>HSOTG_INTEN</b>            | HSOTG_BA+0x08 | R/W | HSOTG Interrupt Enable Register | 0x0000_0000 |
| <b>HSOTG_INTSTS</b>           | HSOTG_BA+0x0C | R/W | HSOTG Interrupt Status Register | 0x0000_0000 |
| <b>HSOTG_STATUS</b>           | HSOTG_BA+0x10 | R   | HSOTG Status Register           | 0x0000_0006 |

### 6.34.7 Register Description

#### HSOTG Control Register (HSOTG\_CTL)

| Register  | Offset        | R/W | Description            |  |  | Reset Value |
|-----------|---------------|-----|------------------------|--|--|-------------|
| HSOTG_CTL | HSOTG_BA+0x00 | R/W | HSOTG Control Register |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [5]    | WKEN        | <b>OTG ID Pin Wake-up Enable Bit</b><br>0 = OTG ID pin status change wake-up function Disabled.<br>1 = OTG ID pin status change wake-up function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4]    | OTGEN       | <b>OTG Function Enable Bit</b><br>User needs to set this bit to enable OTG function while USB frame configured as OTG device. When USB frame not configured as OTG device, this bit is must be low.<br>0= OTG function Disabled.<br>1 = OTG function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [2]    | HNPREQEN    | <b>OTG HNP Request Enable Bit</b><br>When USB frame as A-device, set this bit when A-device allows to process HNP protocol—A-device changes role from Host to Peripheral. This bit will be cleared when OTG state changes from a_suspend to a_peripheral or goes back to a_idle state.<br>When USB frame as B-device, set this bit after the OTG A-device successfully sends a SetFeature (b_hnp_enable) command to the OTG B-device to start role change—B-device changes role from Peripheral to Host. This bit will be cleared when OTG state changes from b_peripheral to b_wait_acon or goes back to b_idle state.<br>0 = HNP request Disabled.<br>1 = HNP request Enabled (A-device can change role from Host to Peripheral or B-device can change role from Peripheral to Host).<br><b>Note:</b> Refer to OTG specification to get a_suspend, a_peripheral, a_idle and b_idle state. |
| [1]    | BUSREQ      | <b>OTG Bus Request</b><br>If OTG A-device wants to do data transfers via USB bus, setting this bit will drive VBUS high to detect USB device connection. If user won't use the bus any more, clearing this bit will drop VBUS to save power. This bit will be cleared when A-device goes to A_wait_vfall state. This bit will be also cleared if VBUSDROP (OTG_CTL[0]) bit is set or IDSTS (OTG_STATUS[1]) changed.<br>If user of an OTG-B Device wants to request VBUS, setting this bit will run SRP protocol.                                                                                                                                                                                                                                                                                                                                                                            |

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <p>This bit will be cleared if SRP failure (OTG A-device does not provide VBUS after B-device issues ARP in specified interval, defined in OTG specification). This bit will be also cleared if VBUSDROP (OTG_CTL[0]) bit is set IDSTS (OTG_STATUS[1]) changed.</p> <p>0 = Do not launch VBUS in OTG A-device or not request SRP in OTG B-device.<br/>1 = Launch VBUS in OTG A-device or request SRP in OTG B-device.</p> |
| [0]  | <p><b>Drop VBUS Control</b></p> <p>If user application running on this OTG A-device wants to conserve power, set this bit to drop VBUS. BUSREQ (OTG_CTL[1]) will be also cleared no matter A-device or B-device.</p> <p>0 = Do not drop the VBUS.<br/>1 = Drop the VBUS.</p>                                                                                                                                              |

**HSOTG PHY Control Register (HSOTG\_PHYCTL)**

| Register     | Offset        | R/W | Description                |  |  | Reset Value |
|--------------|---------------|-----|----------------------------|--|--|-------------|
| HSOTG_PHYCTL | HSOTG_BA+0x04 | R/W | HSOTG PHY 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 |    | VBSTSPOL | VBNPOL | Reserved |    | IDDETEN | OTGPHYEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [5]    | VBSTSPOL    | <p><b>Off-chip USB VBUS Power Switch Status Polarity</b><br/> The polarity of off-chip USB VBUS power switch valid signal depends on the selected component. A USB_VBUS_ST pin is used to monitor the valid signal of the off-chip USB VBUS power switch. Set this bit as following according to the polarity of off-chip USB VBUS power switch.<br/> 0 = The polarity of off-chip USB VBUS power switch valid status is high.<br/> 1 = The polarity of off-chip USB VBUS power switch valid status is low.</p>                                                                                   |
| [4]    | VBNPOL      | <p><b>Off-chip USB VBUS Power Switch Enable Polarity</b><br/> The OTG controller will enable off-chip USB VBUS power switch to provide VBUS power when need. A USB_VBUS_EN pin is used to control the off-chip USB VBUS power switch.<br/> The polarity of enabling off-chip USB VBUS power switch (high active or low active) depends on the selected component. Set this bit as following according to the polarity of off-chip USB VBUS power switch.<br/> 0 = The off-chip USB VBUS power switch enable is active high.<br/> 1 = The off-chip USB VBUS power switch enable is active low.</p> |
| [3:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [1]    | IDDETEN     | <p><b>ID Detection Enable Bit</b><br/> 0 = Detect ID pin status Disabled.<br/> 1 = Detect ID pin status Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [0]    | OTGPHYEN    | <p><b>OTG PHY Enable</b><br/> When USB frame is configured as OTG-device or ID-dependent, user needs to set this bit before using OTG function. If device is not configured as OTG-device nor ID-dependent, this bit is "don't care".<br/> 0 = OTG PHY Disabled.<br/> 1 = OTG PHY Enabled.</p>                                                                                                                                                                                                                                                                                                    |

**HSOTG Interrupt Enable Register (HSOTG\_INTEN)**

| Register        | Offset        | R/W | Description                     |  | Reset Value |
|-----------------|---------------|-----|---------------------------------|--|-------------|
| HSOTG_INTE<br>N | HSOTG_BA+0x08 | R/W | HSOTG 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 |          | SRPDETIEN | Reserved  | SECHGIEN | VBCHGIEN | AVLDCHGIEN | BVLDCHGIEN |
| 7        | 6        | 5         | 4         | 3        | 2        | 1          | 0          |
| HOSTIEN  | PDEVIEEN | IDCHGIEN  | GOIDLEIEN | HNPFIEN  | SRPFIEN  | VBEIEN     | ROLECHGIEN |

| Bits    | Description |                                                                                                                                                                                                                                                                  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                        |
| [13]    | SRPDETIEN   | <b>SRP Detected Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                                    |
| [12]    | Reserved    | Reserved.                                                                                                                                                                                                                                                        |
| [11]    | SECHGIEN    | <b>SESSEND Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and SESSEND (OTG_STATUS[2]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.             |
| [10]    | VBCHGIEN    | <b>VBUSVLD Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and VBUSVLD (OTG_STATUS[5]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.             |
| [9]     | AVLDCHGIEN  | <b>A-device Session Valid Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and AVLD (OTG_STATUS[4]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |
| [8]     | BVLDCHGIEN  | <b>B-device Session Valid Status Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and BVLD (OTG_STATUS[3]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |
| [7]     | HOSTIEN     | <b>Act As Host Interrupt Enable Bit</b><br>If this bit is set to 1 and the device is changed as a host, a interrupt will be asserted.                                                                                                                            |

| Bits | Description                                                                                                                                                                                                                                                                                  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 0 = This device as a host interrupt Disabled.<br>1 = This device as a host interrupt Enabled.                                                                                                                                                                                                |
| [6]  | <b>PDEVIEEN</b><br><b>Act As Peripheral Interrupt Enable Bit</b><br>If this bit is set to 1 and the device is changed as a peripheral, a interrupt will be asserted.<br>0 = This device as a peripheral interrupt Disabled.<br>1 = This device as a peripheral interrupt Enabled.            |
| [5]  | <b>IDCHGIEN</b><br><b>IDSTS Changed Interrupt Enable Bit</b><br>If this bit is set to 1 and IDSTS (OTG_STATUS[1]) status is changed from high to low or from low to high, a interrupt will be asserted.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                 |
| [4]  | <b>GOIDLEIEN</b><br><b>OTG Device Goes to IDLE State Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> Going to idle state means going to a_idle or b_idle state. Please refer to A-device state diagram and B-device state diagram in OTG spec. |
| [3]  | <b>HNPFIEN</b><br><b>HNP Fail Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                                                  |
| [2]  | <b>SRPFIEN</b><br><b>SRP Fail Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                                                  |
| [1]  | <b>VBEIEN</b><br><b>VBUS Error Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br><b>Note:</b> VBUS error means going to a_vbus_err state. Please refer to A-device state diagram in OTG spec.                                                                 |
| [0]  | <b>ROLECHGIEN</b><br><b>Role (Host or Peripheral) Changed Interrupt Enable Bit</b><br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                      |

**HSOTG Interrupt Status Register (HSOTG\_INTSTS)**

| Register            | Offset        | R/W | Description                     |  |  | Reset Value |
|---------------------|---------------|-----|---------------------------------|--|--|-------------|
| <b>HSOTG_INTSTS</b> | HSOTG_BA+0x0C | R/W | HSOTG 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      |               | SRPDETIF       | Reserved        | SECHGIF       | VBCHGIF       | AVLDCHGIF    | BVLDCHGIF        |
| 7             | 6             | 5              | 4               | 3             | 2             | 1            | 0                |
| <b>HOSTIF</b> | <b>PDEVIF</b> | <b>IDCHGIF</b> | <b>GOIDLEIF</b> | <b>HNPFIF</b> | <b>SRPFIF</b> | <b>VBEIF</b> | <b>ROLECHGIF</b> |

| Bits    | Description      |                                                                                                                                                                                                                    |
|---------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                          |
| [13]    | <b>SRPDETIF</b>  | <b>SRP Detected Interrupt Status</b><br>0 = SRP not detected.<br>1 = SRP detected.<br><b>Note:</b> Write 1 to clear this status.                                                                                   |
| [12]    | <b>Reserved</b>  | Reserved.                                                                                                                                                                                                          |
| [11]    | <b>SECHGIF</b>   | <b>SESEND State Change Interrupt Status</b><br>0 = SESSEND (OTG_STATUS[2]) not toggled.<br>1 = SESSEND (OTG_STATUS[2]) from high to low or from low to high.<br><b>Note:</b> Write 1 to clear this flag.           |
| [10]    | <b>VBCHGIF</b>   | <b>VBUSVLD State Change Interrupt Status</b><br>0 = VBUSVLD (OTG_STATUS[5]) not toggled.<br>1 = VBUSVLD (OTG_STATUS[5]) from high to low or from low to high.<br><b>Note:</b> Write 1 to clear this status.        |
| [9]     | <b>AVLDCHGIF</b> | <b>A-device Session Valid State Change Interrupt Status</b><br>0 = AVLD (OTG_STATUS[4]) not toggled.<br>1 = AVLD (OTG_STATUS[4]) from high to low or low to high.<br><b>Note:</b> Write 1 to clear this status.    |
| [8]     | <b>BVLDCHGIF</b> | <b>B-device Session Valid State Change Interrupt Status</b><br>0 = BVLD (OTG_STATUS[3]) is not toggled.<br>1 = BVLD (OTG_STATUS[3]) from high to low or low to high.<br><b>Note:</b> Write 1 to clear this status. |
| [7]     | <b>HOSTIF</b>    | <b>Act As Host Interrupt Status</b><br>0= This device does not act as a host.<br>1 = This device acts as a host.                                                                                                   |

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>Note:</b> Write 1 to clear this flag.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [6]  | <p><b>PDEVIF</b></p> <p><b>Act As Peripheral Interrupt Status</b><br/>           0= This device does not act as a peripheral.<br/>           1 = This device acts as a peripheral.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                                                                                                                                                                                                                                                                                          |
| [5]  | <p><b>IDCHGIF</b></p> <p><b>ID State Change Interrupt Status</b><br/>           0 = IDSTS (OTG_STATUS[1]) not toggled.<br/>           1 = IDSTS (OTG_STATUS[1]) from high to low or from low to high.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                                                                                                                                                                                                                                                                       |
| [4]  | <p><b>GOIDLEIF</b></p> <p><b>OTG Device Goes to IDLE Interrupt Status</b><br/>           Flag is set if the OTG device transfers from non-idle state to idle state. The OTG device will be neither a host nor a peripheral.<br/>           0 = OTG device does not go back to idle state (a_idle or b_idle).<br/>           1 = OTG device goes back to idle state(a_idle or b_idle).</p> <p><b>Note 1:</b> Going to idle state means going to a_idle or b_idle state. Please refer to OTG specification.</p> <p><b>Note 2:</b> Write 1 to clear this flag.</p> |
| [3]  | <p><b>HNPFIF</b></p> <p><b>HNP Fail Interrupt Status</b><br/>           When A-device has granted B-device to be host and USB bus is in SEO (both USB_D+ and USB_D- low) state, this bit will be set when A-device does not connect after specified interval expires.<br/>           0 = A-device connects to B-device before specified interval expires.<br/>           1 = A-device does not connect to B-device before specified interval expires.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                       |
| [2]  | <p><b>SRPFIF</b></p> <p><b>SRP Fail Interrupt Status</b><br/>           After initiating SRP, an OTG B-device will wait for the OTG A-device to drive VBUS high at least TB_SRP_FAIL minimum, defined in OTG specification. This flag is set when the OTG B-device does not get VBUS high after this interval.<br/>           0 = OTG B-device gets VBUS high before this interval.<br/>           1 = OTG B-device does not get VBUS high before this interval.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                            |
| [1]  | <p><b>VBEIF</b></p> <p><b>VBUS Error Interrupt Status</b><br/>           This bit will be set when voltage on VBUS cannot reach a minimum valid threshold 4.4V within a maximum time of 100ms after OTG A-device starting to drive VBUS high.<br/>           0 = OTG A-device drives VBUS over threshold voltage before this interval expires.<br/>           1 = OTG A-device cannot drive VBUS over threshold voltage before this interval expires.</p> <p><b>Note:</b> Write 1 to clear this flag and recover from the VBUS error state.</p>                 |
| [0]  | <p><b>ROLECHGIF</b></p> <p><b>OTG Role Change Interrupt Status</b><br/>           This flag is set when the role of an OTG device changed from a host to a peripheral, or changed from a peripheral to a host while USB_ID pin status does not change.<br/>           0 = OTG device role not changed.<br/>           1 = OTG device role changed.</p> <p><b>Note:</b> Write 1 to clear this flag.</p>                                                                                                                                                          |

**HSOTG Functional Status Register (HSOTG\_STATUS)**

| Register     | Offset        | R/W | Description           |  |  |  | Reset Value |
|--------------|---------------|-----|-----------------------|--|--|--|-------------|
| HSOTG_STATUS | HSOTG_BA+0x10 | R   | HSOTG Status Register |  |  |  | 0x0000_0006 |

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

| Bits   | Description |                                                                                                                                                                                                |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                      |
| [7]    | ASHOST      | <b>As Host Status</b><br>When OTG acts as Host, this bit is set.<br>0 = OTG not as Host.<br>1 = OTG as Host.                                                                                   |
| [6]    | ASPERI      | <b>As Peripheral Status</b><br>When OTG acts as peripheral, this bit is set.<br>0 = OTG not as peripheral.<br>1 = OTG as peripheral.                                                           |
| [5]    | VBUSVLD     | <b>VBUS Valid Status</b><br>When VBUS is larger than 4.7V and A-device drives VBUS, this bit will be set to 1.<br>0 = VBUS is not valid.<br>1 = VBUS is valid.                                 |
| [4]    | AVLD        | <b>A-device Session Valid Status</b><br>0 = A-device session is not valid.<br>1 = A-device session is valid.                                                                                   |
| [3]    | BVLD        | <b>B-device Session Valid Status</b><br>0 = B-device session is not valid.<br>1 = B-device session is valid.                                                                                   |
| [2]    | SESEND      | <b>Session End Status</b><br>When VBUS voltage is lower than 0.4V, this bit will be set to 1. Session end means no meaningful power on VBUS.<br>0 = Session is not end.<br>1 = Session is end. |
| [1]    | IDSTS       | <b>USB_ID Pin State of Mini-b/Micro-plug</b>                                                                                                                                                   |

| Bits | Description    |                                                                                                                                                                                                                                                                                                |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                | 0 = Mini-A/Micro-A plug is attached.<br>1 = Mini-B/Micro-B plug is attached.                                                                                                                                                                                                                   |
| [0]  | <b>OVERCUR</b> | <b>Overcurrent Condition</b><br>The voltage on VBUS cannot reach a minimum VBUS valid threshold, 4.4V minimum, within a maximum time of 100ms after OTG A-device drives VBUS high.<br>0 = OTG A-device drives VBUS successfully.<br>1 = OTG A-device cannot drives VBUS high in this interval. |

## 6.35 CRC Controller (CRC)

### 6.35.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.35.2 Features

- Supports four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32
  - CRC-CCITT:  $X^{16} + X^{12} + X^5 + 1$
  - CRC-8:  $X^8 + X^2 + X + 1$
  - CRC-16:  $X^{16} + X^{15} + X^2 + 1$
  - CRC-32:  $X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X + 1$
- 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.35.3 Block Diagram



Figure 6.35-1 CRC Generator Block Diagram

#### 6.35.4 Basic Configuration

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

#### 6.35.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 CRC 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 functional block is also shown in Figure 6.35-2 CHECKSUM Bit Order Reverse Functional Block
  - 2) Configure 1's complement for CRC write data by setting DATFMT (CRC\_CTL[26] Write Data 1's Complement).
  - 3) 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.35-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.35-2 CHECKSUM Bit Order Reverse Functional Block



Figure 6.35-3 Write Data Bit Order Reverse Functional Block

### 6.35.6 Register Map

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

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

### 6.35.7 Register Description

#### CRC Control Register (CRC\_CTL)

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



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

|        |                 |                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [25]   | <b>CHKSREV</b>  | <b>Checksum Bit Order Reverse</b><br>This bit is used to enable the bit order reverse function for checksum result in CRC_CHECKSUM register.<br>0 = Bit order reverse for CRC checksum Disabled.<br>1 = Bit order reverse for CRC checksum Enabled.<br><b>Note:</b> If the checksum result is 0xDD7B0F2E, the bit order reverse for CRC checksum is 0x74F0DEBB.                               |
| [24]   | <b>DATREV</b>   | <b>Write Data Bit Order Reverse</b><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><b>Note:</b> If the write data is 0xAABBCCDD, the bit order reverse for CRC write data in is 0x55DD33BB. |
| [23:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |
| [1]    | <b>CHKSINIT</b> | <b>Checksum Initialization</b><br>0 = No effect.<br>1 = Initial checksum value by auto reload CRC_SEED register value to CRC_CHECKSUM register value.<br><b>Note:</b> This bit will be cleared automatically.                                                                                                                                                                                 |
| [0]    | <b>CRCEN</b>    | <b>CRC Channel Enable Bit</b><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+0x04 | R/W | CRC Write Data Register |  |  |  | 0x0000_0000 |

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

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

CRC Seed Register (CRC\_SEED)

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

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

| Bits   | Description |                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>SEED</b> | <b>CRC Seed Value</b><br>This field indicates the CRC seed value.<br><b>Note:</b> This field will be reloaded as checksum initial value (CRC_CHECKSUM register) after perform CHKSINIT (CRC_CTL[1]). |

CRC Checksum Register (CRC\_CHECKSUM)

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



| Bits   | Description     |                                                                              |
|--------|-----------------|------------------------------------------------------------------------------|
| [31:0] | <b>CHECKSUM</b> | <b>CRC Checksum Results</b><br>This field indicates the CRC checksum result. |

## 6.36 Cryptographic Accelerator (CRYPTO)

### 6.36.1 Overview

The Crypto (Cryptographic Accelerator) includes a secure pseudo random number generator (PRNG) core and supports AES, DES/TDES, SHA and HMAC algorithms.

The PRNG core supports 64 bits, 128 bits, 192 bits, and 256 bits random number generation.

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 CBC-CS3 mode.

The DES/TDES accelerator is an implementation fully compliant with the DES and Triple DES encryption/decryption algorithm. The DES/TDES accelerator supports ECB, CBC, CFB, OFB, and CTR mode.

The SHA accelerator is an implementation fully compliant with the SHA-160, SHA-224, SHA-256, SHA-384, and SHA-512 and corresponding HMAC algorithms.

The ECC accelerator is an implementation fully compliant with elliptic curve cryptography by using polynomial basis in binary field and prime filed.

### 6.36.2 Features

- PRNG
  - Supports 64 bits, 128 bits, 192 bits, and 256 bits random number generation
- 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
- DES
  - Supports FIPS 46-3
  - Supports both encryption and decryption
  - Supports ECB, CBC, CFB, OFB, and CTR mode
- TDES
  - Supports FIPS NIST 800-67
  - Implemented according to the X9.52 standard
  - Supports two keys or three keys mode
  - Supports both encryption and decryption
  - Supports ECB, CBC, CFB, OFB, and CTR mode
- SHA
  - Supports FIPS NIST 180, 180-2
  - Supports SHA-160, SHA-224, SHA-256, SHA-384, and SHA-512
- HMAC

- Supports FIPS NIST 180, 180-2
- Supports HMAC-SHA-160, HMAC-SHA-224, HMAC-SHA-256, HMAC-SHA-384, and HMAC-SHA-512
- ECC
  - Supports both prime field GF( $p$ ) and binary field GF( $2^m$ )
  - Supports NIST P-192, P-224, P-256, P-384, and P-521
  - Supports NIST B-163, B-233, B-283, B-409, and B-571
  - Supports NIST K-163, K-233, K-283, K-409, and K-571
  - Supports point multiplication, addition and doubling operations in GF( $p$ ) and GF( $2^m$ )
  - Supports modulus division, multiplication, addition and subtraction operations in GF( $p$ )

### 6.36.3 Block Diagram



Figure 6.36-1 Cryptographic Accelerator Block Diagram

#### 6.36.4 Basic Configuration

- Clock Source Configuration
  - Enable CRYPTO peripheral clock in CRYPTOCKEN (CLK\_AHBCLK[12])
- Reset Configuration
  - Reset CRYPTO controller in CRYPTORST (SYS\_IPRST0[12])

#### 6.36.5 Functional Description

The cryptographic accelerator includes a secure pseudo random number generator (PRNG) core and supports AES, DES/TDES, SHA, HMAC and ECC algorithms. The accelerator can be used in different data security applications, such as secure communications that need cryptographic protection and integrity.

1. The PRNG core supports 64 bits, 128 bits, 192 bits, and 256 bits random number generation configured by KEYSZ.

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, CBC-CS1, 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.

2. The DES/TDES accelerator is a fully compliant implementation of the DES and Triple DES encryption/decryption algorithm. The DES/TDES accelerator supports ECB, CBC, CFB, OFB, and CTR mode. The DES/TDES accelerator also supports the DMA function to reduce the CPU intervention. Only two burst lengths, four words and eight words, are supported.
3. The SHA/HMAC accelerator is a fully compliant implementation of the SHA-160, SHA-224, SHA-256, SHA-384, SHA-512, and corresponding HMAC algorithm. The SHA/HMAC accelerator also supports the DMA function to reduce the CPU intervention. It supports three burst lengths, sixteen-words, eight-words, and four-words.
4. The ECC accelerator is a fully compliant implementation of the prime field GF(p) and binary field GF(2<sup>m</sup>) algorithm. The prime field GF(p) supports NIST P-192, P-224, P-256, P-384 and P-521. The binary field GF(2<sup>m</sup>) supports NIST B-163, B-233, B-283, B-409, B-571 and NIST K-163, K-233, K-283, K-409 and K-571.

Software can control the data flow by enabling the CRYPTO\_INTEN, and monitor the accelerator status by checking the CRYPTO\_INTSTS. When any engine happened operation error or buffer error, the corresponding error flag will 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 each engine. Table 6.36-1 lists each engine error enable bit, error flag bit and error conditions.

| Engine   | Error Interrupt Enable Bit  | Error Interrupt Flag        | Error Conditions          |
|----------|-----------------------------|-----------------------------|---------------------------|
| AES      | AESEIEN (CRYPTO_INTEN[1])   | AESEIF (CRYPTO_INTSTS[1])   | INBUFERR/OUTBUFERR/BUSERR |
| TDES/DES | TDESEIEN (CRYPTO_INTEN[9])  | TDEEIF (CRYPTO_INTSTS[9])   | INBUFERR/OUTBUFERR/BUSERR |
| SHA/HMAC | HMACEIEN (CRYPTO_INTEN[25]) | HMACEIF (CRYPTO_INTSTS[25]) | DMAERR/BUSERR             |
| ECC      | ECCEIEN (CRYPTO_INTEN[23])  | ECCEIF (CRYPTO_INTSTS[23])  | BUSERR                    |

Table 6.36-1 Each 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 four hardware DMA channels for AES engine, four hardware DMA channels for DES/TDES engine, and one hardware DMA channel for SHA/HMAC engine.

| Engine   | DMA Enable Bit             |
|----------|----------------------------|
| AES      | DMAEN (CRYPTO_AES_CTL[7])  |
| TDES/DES | DMAEN (CRYPTO_TDES_CTL[7]) |
| SHA/HMAC | DMAEN (CRYPTO_HMAC_CTL[7]) |
| ECC      | DMAEN (CRYPTO_ECC_CTL[7])  |

Table 6.36-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])  |
| TDES/DES | DMACSCAD (CRYPTO_TDES_CTL[6]) |

Table 6.36-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.

**Channel Expansion Mode**

In this mode, several virtual channels in one of four DMA channels are feasible in AES or DES/TDES mode. The total channel number can exceed the limit of four DMA channels. The intermediate data from feedback registers (CRYPTO\_AES\_FDBCKx, CRYPTO\_TDES\_FDBCKH, and CRYPTO\_TDES\_FDBCKL) should be stored temporarily in data SRAM. And switch to another configuration setting of accelerator operation that includes operational mode, encryption/decryption, key, key size, IV, and other parameters. Once switching back, the intermediate data from feedback registers should be written to initial vectors (CRYPTO\_AESn\_IVx, CRPY\_TDESx\_IVH, and CRYPTO\_TDESx\_IVL) for the accelerator to continue the operation with the original configuration setting. Note that, in ECB mode, there is no need to move the intermediate data from feedback registers to IV.

| Engine   | Channel Selection Bits           |
|----------|----------------------------------|
| AES      | CHANNEL (CRYPTO_AES_CTL[25,24])  |
| TDES/DES | CHANNEL (CRYPTO_TDES_CTL[25,24]) |

Table 6.36-4 Channel Selection Bit Table

### 6.36.5.2 PRNG (Pseudo Random Number Generator)

The PRNG block diagram is depicted in Figure 6.36-2. The core supports 64 bits, 128 bits, 192 bits, and 256 bits random number generation configured by KEYSZ(CRYPTO\_PRNG\_CTL[3:2]).



Figure 6.36-2 PRNG Function Diagram

Program steps to get the pseudo random number are depicted below.

1. Check the BUSY(CRYPTO\_PRNG\_CTL[8]) until it comes to 0.
2. Initialize PRNG parameters. Configure KEYSZ (CRYPTO\_PRNG\_CTL[3:2]), and write a random seed to CRYPTO\_PRNG\_SEED. Note that CRYPTO\_PRNG\_SEED should be initialized since it's not initialized as the chip powers up.
3. Configure PRNG control register CRYPTO\_PRNG\_CTL for key size(KEYSZ), seed reload(SEEDRLD), and PRNG start(START).
4. Software checks BUSY(CRYPTO\_PRNG\_CTL[8]) until it comes to 0, or waits for the PRNGIF (CRYPTO\_INTSTS[16]) (must enable PRNGIEN (CRYPTO\_INTEN[16])). Then software can read the output random numbers (KEY) from CRYPTO\_PRNG\_KEY0 ~ CRYPTO\_PRNG\_KEY7.

### 6.36.5.3 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  $CIPH^{-1}_k$  directly and independently. The resulting sequence of output blocks is the plaintext.



Figure 6.36-3 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.36-4 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.36-5 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.36-6 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.36-7 Counter Mode

**CBC Ciphertext-Stealing 1 Mode (CBC-CS1)**

Figure 6.36-8 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.36-8 CBC-CS1 Encryption

Figure 6.36-9 illustrates the CBC-CS1-Decrypt algorithm for the case that  $C_{n-1}^*$  is a partial block.



Figure 6.36-9 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. Select one from four DMA channels.
3. Program AES key to registers CRYPTO\_AESn\_KEY0 ~ CRYPTO\_AESn\_KEY7. (where n is the selected channel number)
4. Program initial vectors to registers CRYPTO\_AESn\_IV0 ~ CRYPTO\_AESn\_IV3.
5. Program DMA source address to register CRYPTO\_AESn\_SADDR.
6. Program DMA destination address to register CRYPTO\_AESn\_DADDR.
7. Program DMA byte count to register CRYPTO\_AESn\_CNT.
8. Configure AES control register CRYPTO\_AES\_CTL for key protection(KEYPRT), channel selection(CHANNEL), encryption/decryption(ENCRYPTO), operational mode(OPMODE), DMA mode, key size(KEYSZ), and DMA input/output swap(INSWAP/OUTSWAP).
9. Write input data to DMA source address with selected DMA byte count.
10. Write 1 to START(CRYPTO\_AES\_CTL[0]) to start AES encryption/decryption.

11. Wait for the AES interrupt flag AESIF (CRYPTO\_INTSTS[0]) be set.
12. Read output data from DMA destination address with selected DMA byte count.
13. Repeat step 9 to step 12 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\_AESn\_KEY0 ~ CRYPTO\_AESn\_KEY7. (where n is the selected channel number)
3. Program initial vectors to register CRYPTO\_AESn\_IV0 ~ CRYPTO\_AESn\_IV3.
4. Configure AES control register (CRYPTO\_AES\_CTL) for key protection(KEYPRT), channel select(CHANNEL), encryption/decryption(ENCRYPTO), operational mode(OPMODE), and key size(KEYSZ).
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(CRYPTO\_AES\_STS[9]) is 0, write 32 bits input data to CRYPTO\_AES\_DATIN. If OUTBUFEMPTY(CRYPTO\_AES\_STS[16]) is 0, read 32 bits data from CRYPTO\_AES\_DATOUT.
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 register CRYPTO\_AES\_CNT if current operation is last operation.
10. Repeat steps 6 to step 9 until all data processed.

#### 6.36.5.4 DES/TDES (Data Encryption Standard / Triple DES)

FIPS 46-3 specifies two cryptographic algorithms, the Data Encryption Standard(DES) and the Triple Data Encryption Algorithm (TDEA). The cryptographic accelerator supports FIPS 46-3, both encryption and decryption, and ECB, CBC, CFB, OFB and CTR modes.

#### TDES DMA Mode Programming Flow

1. Write 1 to TDESIEN (CRYPTO\_INTEN[8]) to enable TDES interrupt if needed.
2. Check the TDES engine is in idle state, i.e., BUSY(CRYPTO\_TDES\_STS [0]) is 0.
3. Program TDES key to registers CRYPTO\_TDESn\_KEY1H, CRYPTO\_TDESn\_KEY1L, CRYPTO\_TDESn\_KEY2H, CRYPTO\_TDESn\_KEY2L, CRYPTO\_TDESn\_KEY3H, and CRYPTO\_TDESn\_KEY3L. (where n is the selected channel number)
4. Program initial vector to registers CRYPTO\_TDESn\_IVH and CRYPTO\_TDESn\_IVL.
5. Program DMA source address to register CRYPTO\_TDESn\_SA.
6. Program DMA destination address to register CRYPTO\_TDESn\_DA.
7. Program DMA byte count to register CRYPTO\_TDESn\_CNT.
8. Configure TDES control register CRYPTO\_TDES\_CTL for channel selection(CHANNEL), encryption/decryption(ENCRYPTO), operational mode(OPMODE), DMA mode(DMAEN), TDES keys(3KEYS), TDES mode(TMODE), and DMA input/output swap(INSWAP/OUTSWAP).
9. Write input data to DMA source address with selected DMA byte count.
10. Write 1 to START(CRYPTO\_TDES\_CTL[0]) to start TDES encryption/decryption.
11. Wait for the TDES interrupt flag TDESIF (CRYPTO\_INTSTS[8]) be set.
12. Read output data from DMA destination address with selected DMA byte count.

13. Repeat step 9 to step 12 until all data processed if enabled DMACSCAD (CRYPTO\_TDES\_CTL[6]).

#### TDES Non-DMA Mode Programming Flow

1. Write 1 to TDESIEN (CRYPTO\_INTEN[8]) to enable TDES interrupt if needed.
2. Check the TDES engine is in idle state, i.e., BUSY(CRYPTO\_TDES\_STS[0]) is 0.
3. Program TDES key to registers CRYPTO\_TDES<sub>n</sub>\_KEY1H, CRYPTO\_TDES<sub>n</sub>\_KEY1L, CRYPTO\_TDES<sub>n</sub>\_KEY2H, CRYPTO\_TDES<sub>n</sub>\_KEY2L, CRYPTO\_TDES<sub>n</sub>\_KEY3H, and CRYPTO\_TDES<sub>n</sub>\_KEY3L. (where n is the selected channel number)
4. Program initial vector to registers CRYPTO\_TDES<sub>n</sub>\_IVH and CRYPTO\_TDES<sub>n</sub>\_IVL.
5. Configure TDES control register CRYPTO\_TDES\_CTL for channel selection(CHANNEL), encryption/decryption(ENCPRT), operational mode(OPMODE), TDES keys(3KEYS), and TDES mode(TMODE).
6. Write 1 to START(CRYPTO\_TDES\_CTL[0]) to start TDES encryption/decryption.
7. Polling INBUFFULL(CRYPTO\_TDES\_STS[9]) and OUTBUFEMPTY(CRYPTO\_TDES\_STS[16]). If INBUFFULL(CRYPTO\_TDES\_STS[9]) is 0, write 32 bits input data to CRYPTO\_TDES\_DATIN. If OUTBUFEMPTY(CRYPTO\_TDES\_STS[16]) is 0, read 32 bits data from CRYPTO\_TDES\_DATAOUT.
8. Repeat step 7 until 64 bits data (8 bytes) are written to and read from TDES engine.
9. Write 1 to DMALAST(CRYPTO\_TDES\_CTL[5]) if current operation is last operation
10. Write data byte count of last operation to register CRYPTO\_TDES\_CNT if current operation is last operation.
11. Repeat steps 7 to step 10 until all data processed.

#### 6.36.5.5 SHA (Secure Hash Algorithm)

User can refer to the following steps to understand how to program the SHA related registers.

#### SHA DMA Mode Programming Flow

1. Write 1 to HMACIEN(CRYPTO\_INTEN[24]) to enable SHA/HMAC interrupt if needed.
2. Configure SHA/HMAC control register CRYPTO\_HMAC\_CTL for SHA/HMAC engine input/output data swap(INSWAP/OUTSWAP), DMA mode(DMAEN), and SHA operation mode(OPMODE). Clear HMACEN(CRYPTO\_HMAC\_CTL[4]) to select SHA mode.
3. Program DMA source address to register CRYPTO\_HMAC\_SADDR.
4. Program DMA byte count to register CRYPTO\_HMAC\_DMACNT.
5. Write input data to DMA source address with selected DMA byte count.
6. Write 1 to START(CRYPTO\_HMAC\_CTL[0]) to start SHA encryption.
7. Wait for the SHA interrupt flag HMACIF(CRYPTO\_INTSTS[24]) be set.
8. Read output digest (SHA160: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST4, SHA224: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST6, SHA256: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST7, SHA384: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST11, SHA512: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST15).

**Note:** The KEYCNT(CRYPTO\_HMAC\_KEYCNT[31:0]) keeps the byte count of key that SHA/HMAC engine operates.

#### SHA Non-DMA mode programming flow:

1. Configure SHA/HMAC control register CRYPTO\_HMAC\_CTL for SHA/HMAC engine input/output data swap(INSWAP/OUTSWAP) and SHA operation mode(OPMODE). Clear HMACEN(CRYPTO\_HMAC\_CTL[4]) to select SHA mode.

2. If it's the last input word, set DMALAST(CRYPTO\_HMAC\_CTL[5]).
3. Write 1 to START(CRYPTO\_HMAC\_CTL[0]) to start SHA encryption.
4. Wait for the SHA data input request DATINREQ(CRYPTO\_HMAC\_STS[16]) be set.
5. Write one word of input data to CRYPTO\_HMAC\_DATIN.
6. Repeat step 2 to 5 until all inut words are written into SHA engine.
7. Wait for the BUSY (CRYPTO\_HMAC\_STS[0]) be cleared.
8. Read output digest (SHA160: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST4, SHA224: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST6, SHA256: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST7, SHA384: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST11, SHA512: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST15).

**Note:** The KEYCNT(CRYPTO\_HMAC\_KEYCNT[31:0]) keeps the byte count of key that SHA/HMAC engine operates.

#### 6.36.5.6 HMAC (*Keyed-Hash Message Authentication Code*)

The Keyed-Hash Message Authentication Code is a specific construction for calculating a message authentication code involving a cryptographic hash function in combination with a secret cryptographic key. Any cryptographic hash function, such as SHA-1, may be used in the calculation of an HMAC; the resulting MAC algorithm is termed HMAC-SHA1 accordingly.

User can refer to the following steps to understand how to program the HMAC related registers.

##### HMAC DMA Mode Programming Flow

1. Write 1 to HMACIEN(CRYPTO\_INTEN[24]) to enable HMAC interrupt if needed.
2. Configure SHA/HMAC control register CRYPTO\_HMAC\_CTL for HMAC engine input/output data swap(INSWAP/OUTSWAP), DMA mode(DMAEN), and HMAC operation mode(OPMODE). Set HMACEN(CRYPTO\_HMAC\_CTL[4]) to select HMAC mode.
3. Program DMA source address to register CRYPTO\_HMAC\_SADDR.
4. Program DMA byte count to register CRYPTO\_HMAC\_DMACNT.
5. Write input data to DMA source address with selected DMA byte count.
6. Write 1 to START(CRYPTO\_HMAC\_CTL[0]) to start HMAC encryption.
7. Wait for the HMAC interrupt flag HMACIF(CRYPTO\_INTSTS[24]) be set.
8. Read output digest (HMAC-SHA160: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST4, HMAC-SHA224: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST6, HMAC-SHA256: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST7, HMAC-SHA384: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST11, HMAC-SHA512: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST15).

**Note:** The KEYCNT(CRYPTO\_HMAC\_KEYCNT[31:0]) keeps the byte count of key that SHA/HMAC engine operates.

##### HMAC Non-DMA Mode Programming Flow

1. Configure SHA/HMAC control register CRYPTO\_HMAC\_CTL for SHA/HMAC engine input/output data swap(INSWAP/OUTSWAP) and HMAC operation mode(OPMODE). Set HMACEN(CRYPTO\_HMAC\_CTL[4]) to select HMAC mode.
2. If it's the last input word, set DMALAST(CRYPTO\_HMAC\_CTL[5]).
3. Write 1 to START(CRYPTO\_HMAC\_CTL[0]) to start HMAC encryption.
4. Wait for the HMAC data input request DATINREQ(CRYPTO\_HMAC\_STS[16]) be set.
5. Write one word of input data to CRYPTO\_HMAC\_DATIN.

6. Repeat step 2 to 5 until all input words are written into SHA engine.
7. Wait for the BUSY (CRYPTO\_HMAC\_STS[0]) be cleared.
8. Read output digest (HMAC-SHA160: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST4, HMAC-SHA224: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST6, HMAC-SHA256: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST7, HMAC-SHA384: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST11, HMAC-SHA512: CRYPTO\_HMAC\_DGST0 ~ CRYPTO\_HMAC\_DGST15).

**Note:** The KEYCNT(CRYPTO\_HMAC\_KEYCNT[31:0]) keeps the byte count of key that SHA/HMAC engine operates.

#### 6.36.5.7 ECC (*Elliptic Curve Cryptography*)

Elliptic Curve Cryptography (ECC) is a famous approach of public-key cryptosystems. Recently, many protocols and applications utilize the algebraic cyclic group characters of elliptic curves over finite field to build cryptographic systems. All points of an elliptic curve will follow the formula of elliptic curve :  $y^2 \equiv x^3 + Ax + B \pmod{N}$  in  $GF(p)$  and  $y^2 + x^3 \equiv x^3 + Ax^2 + B \pmod{N}$  in  $GF(2^m)$ . Figure 6.27-10 exhibits the main hierarchy chart of ECC applications. The often appeared parameters and corresponding registers are shown in Table 6.36-5.



Figure 6.36-10 Main Hierarchy Chart of ECC

| Parameter | Description                | Corresponding Register             |
|-----------|----------------------------|------------------------------------|
| X1        | The x-coordinate of point1 | CRYPTO_ECC_X1_00~ CRYPTO_ECC_X1_17 |
| Y1        | The y-coordinate of point1 | CRYPTO_ECC_Y1_00~ CRYPTO_ECC_Y1_17 |
| X2        | The x-coordinate of point2 | CRYPTO_ECC_X2_00~ CRYPTO_ECC_X2_17 |
| Y2        | The y-coordinate of point2 | CRYPTO_ECC_Y2_00~ CRYPTO_ECC_Y2_17 |
| A         | The curve parameter A      | CRYPTO_ECC_A_00~ CRYPTO_ECC_A_17   |
| B         | The curve parameter B      | CRYPTO_ECC_B_00~ CRYPTO_ECC_B_17   |
| N         | The curve parameter N      | CRYPTO_ECC_N_00~ CRYPTO_ECC_N_17   |
| M         | The curve length           | CRYPTO_ECC_CTL[31:22]              |
| K         | The scalar constant        | CRYPTO_ECC_K_00~ CRYPTO_ECC_K_17   |

Table 6.36-5 ECC Parameters and Corresponding Registers Table

Scalar multiplication (point multiplication) is the core operation in ECC applications. The computation of scalar multiplication is composed of point addition and point doubling operations. Moreover, there are many finite field modulus arithmetic operations in the formula of point addition and doubling operation. To accelerate ECC applications, we propose an elliptic curve cryptographic accelerator that can process not only three point operations in both GF( $p$ ) and GF( $2^m$ ) but also four modulus operations in GF( $p$ ). Before starting ECC accelerator, user must provide the required input data of ECC operation include point coordinates (X1, Y1, X2, Y2), curve parameters (A, B, N, M) and scalar data (K) in Table 6.36-6 .The mark “√” means that the input data is necessary for this operation. The detail definition of input data and the corresponding registers in the ECC accelerator are exhibited in the next section Register Map.

After ECC accelerator finished, all point operations will generate a output point includes x-coordinate in the registers from CRYPTO\_ECC\_X1\_00 to CRYPTO\_ECC\_X1\_17 and y-coordinate in the registers from CRYPTO\_ECC\_Y1\_00 to CRYPTO\_ECC\_Y1\_17. In all modulus operations, ECC accelerator will only produce a output result in the registers from CRYPTO\_ECC\_X1\_00 to CRYPTO\_ECC\_X1\_17.

| Operation  | PM | PA | PD | MOD_DIV | MOD_MUL | MOD_ADD | MOD_SUB |
|------------|----|----|----|---------|---------|---------|---------|
| ECCOP[1:0] | 00 | 10 | 11 | 01      | 01      | 01      | 01      |
| MODOP[1:0] | XX | XX | XX | 00      | 01      | 10      | 11      |
| X1         | √  | √  | √  | √       | √       | √       | √       |
| Y1         | √  | √  | √  | √       | √       | √       | √       |
| X2         |    | √  |    |         |         |         |         |
| Y2         |    | √  |    |         |         |         |         |
| A          | √  | √  | √  |         |         |         |         |
| B          | √  |    | √  |         |         |         |         |
| N          | √  | √  | √  | √       | √       | √       | √       |
| M          | √  | √  | √  |         | √       |         |         |
| K          | √  |    |    |         |         |         |         |

Table 6.36-6 Required Input Data of Various Operations

User can refer to the following steps to understand how to program the ECC related registers.

#### ECC DMA Mode Programming Flow

1. Write 1 to ECCIEN(CRYPTO\_INTEN[22]) to enable ECC interrupt if needed.
2. Program DMA source address to register CRYPTO\_ECC\_SADDR.
3. Program DMA destination address to register CRYPTO\_ECC\_DADDR.
4. Program DMA word count to register CRYPTO\_ECC\_WORDCNT.
5. Program the starting register address of all input data in Table 6.36-6 that will update to the register CRYPTO\_ECC\_STARTREG.
6. Write input data to DMA source address with selected DMA word count.
7. Configure ECC control register CRYPTO\_ECC\_CTL for ECC accelerator, such as the start signal of ECC accelerator(START), DMA mode enable signal(DMAEN), field selection(FSEL), point operation mode(ECCOP), modulus operation mode(MODOP), the control signals fo all input data registers(LDA, LDB, LDN, LDK, LDP1, LDP2), and the key length of elliptic curve(CURVEM).

8. Wait for the ECC interrupt flag ECCIF(CRYPTO\_INTSTS[22]) be set.
9. Read output data and then clear ECC interrupt flag ECCIF.

### ECC Non-DMA Mode Programming Flow

1. Write all necessary input data in the corresponding registers according to in Table 6.36-6, such as CURVEA, CURVEB, CURVEN, SCALAR.
2. Configure ECC control register CRYPTO\_ECC\_CTL for ECC accelerator, such as the start signal of ECC accelerator(START), field selection(FSEL), point operation mode(ECCOP), modulus operation mode(MODOP), the control signals fo all input data registers(LDA, LDB, LDN, LDK, LDP1, LDP2), and the key length of elliptic curve(CURVEM).
3. Wait for the BUSY (CRYPTO\_ECC\_STS[0]) be cleared.
4. Read output digest and then clear ECC interrupt flag ECCIF.

### Some Notices of ECC Accelerator

1. The key length support of ECC accelerator is from 163 to 256 bits.
2. All input and output data must be positive. (If the input data is negative, it must be added N).
3. The irreducible polynomial of GF(2<sup>m</sup>) must adopt the smallest one from HP, please refer to Table 6.36-7 (Reference from HP, Table of Low-Weight Binary Irreducible Polynomials, HPL-98-135, August, 1998)

|           | 2,1       | 3,1      | 4,1       | 5,2      |
|-----------|-----------|----------|-----------|----------|
| 6,1       | 7,1       | 8,4,3,1  | 9,1       | 10,3     |
| 11,2      | 12,3      | 13,4,3,1 | 14,5      | 15,1     |
| 16,5,3,1  | 17,3      | 18,3     | 19,5,2,1  | 20,3     |
| 21,2      | 22,1      | 23,5     | 24,4,3,1  | 25,3     |
| 26,4,3,1  | 27,5,2,1  | 28,1     | 29,2      | 30,1     |
| 31,3      | 32,7,3,2  | 33,10    | 34,7      | 35,2     |
| 36,9      | 37,6,4,1  | 38,6,5,1 | 39,4      | 40,5,4,3 |
| 41,3      | 42,7      | 43,6,4,3 | 44,5      | 45,4,3,1 |
| 46,1      | 47,5      | 48,5,3,2 | 49,9      | 50,4,3,2 |
| 51,6,3,1  | 52,3      | 53,6,2,1 | 54,9      | 55,7     |
| 56,7,4,2  | 57,4      | 58,19    | 59,7,4,2  | 60,1     |
| 61,5,2,1  | 62,29     | 63,1     | 64,4,3,1  | 65,18    |
| 66,3      | 67,5,2,1  | 68,9     | 69,6,5,2  | 70,5,3,1 |
| 71,6      | 72,10,9,3 | 73,25    | 74,35     | 75,6,3,1 |
| 76,21     | 77,6,5,2  | 78,6,5,3 | 79,9      | 80,9,4,2 |
| 81,4      | 82,8,3,1  | 83,7,4,2 | 84,5      | 85,8,2,1 |
| 86,21     | 87,13     | 88,7,6,2 | 89,38     | 90,27    |
| 91,8,5,1  | 92,21     | 93,2     | 94,21     | 95,11    |
| 96,10,9,6 | 97,6      | 98,11    | 99,6,3,1  | 100,15   |
| 101,7,6,1 | 102,29    | 103,9    | 104,4,3,1 | 105,4    |

|             |            |              |            |             |
|-------------|------------|--------------|------------|-------------|
| 106,15      | 107,9,7,4  | 108,17       | 109,5,4,2  | 110,33      |
| 111,10      | 112,5,4,3  | 113,9        | 114,5,3,2  | 115,8,7,5   |
| 116,4,2,1   | 117,5,2,1  | 118,33       | 119,8      | 120,4,3,1   |
| 121,18      | 122,6,2,1  | 123,2        | 124,19     | 125,7,6,5   |
| 126,21      | 127,1      | 128,7,2,1    | 129,5      | 130,3       |
| 131,8,3,2   | 132,17     | 133,9,8,2    | 134,57     | 135,11      |
| 136,5,3,2   | 137,21     | 138,8,7,1    | 139,8,5,3  | 140,15      |
| 141,10,4,1  | 142,21     | 143,5,3,2    | 144,7,4,2  | 145,52      |
| 146,71      | 147,14     | 148,27       | 149,10,9,7 | 150,53      |
| 151,3       | 152,6,3,2  | 153,1        | 154,15     | 155,62      |
| 156,9       | 157,6,5,2  | 158,8,6,5    | 159,31     | 160,5,3,2   |
| 161,18      | 162,27     | 163,7,6,3    | 164,10,8,7 | 165,9,8,3   |
| 166,37      | 167,6      | 168,15,3,2   | 169,34     | 170,11      |
| 171,6,5,2   | 172,1      | 173,8,5,2    | 174,13     | 175,6       |
| 176,11,3,2  | 177,8      | 178,31       | 179,4,2,1  | 180,3       |
| 181,7,6,1   | 182,81     | 183,56       | 184,9,8,7  | 185,24      |
| 186,11      | 187,7,6,5  | 188,6,5,2    | 189,6,5,2  | 190,8,7,6   |
| 191,9       | 192,7,2,1  | 193,15       | 194,87     | 195,8,3,2   |
| 196,3       | 197,9,4,2  | 198,9        | 199,34     | 200,5,3,2   |
| 201,14      | 202,55     | 203,8,7,1    | 204,27     | 205,9,5,2   |
| 206,10,9,5  | 207,43     | 208,9,3,1    | 209,6      | 210,7       |
| 211,11,10,8 | 212,105    | 213,6,5,2    | 214,73     | 215,23      |
| 216,7,3,1   | 217,45     | 218,11       | 219,8,4,1  | 220,7       |
| 221,8,6,2   | 222,5,4,2  | 223,33       | 224,9,8,3  | 225,32      |
| 226,10,7,3  | 227,10,9,4 | 228,113      | 229,10,4,1 | 230,8,7,6   |
| 231,26      | 232,9,4,2  | 233,74       | 234,31     | 235,9,6,1   |
| 236,5       | 237,7,4,1  | 238,73       | 239,36     | 240,8,5,3   |
| 241,70      | 242,95     | 243,8,5,1    | 244,111    | 245,6,4,1   |
| 246,11,2,1  | 247,82     | 248,15,14,10 | 249,35     | 250,103     |
| 251,7,4,2   | 252,15     | 253,46       | 254,7,2,1  | 255,52      |
| 256,10,5,2  | 257,12     | 258,71       | 259,10,6,2 | 260,15      |
| 261,7,6,4   | 262,9,8,4  | 263,93       | 264,9,6,2  | 265,42      |
| 266,47      | 267,8,6,3  | 268,25       | 269,7,6,1  | 270,53      |
| 271,58      | 272,9,3,2  | 273,23       | 274,67     | 275,11,10,9 |
| 276,63      | 277,12,6,3 | 278,5        | 279,5      | 280,9,5,2   |

|             |             |             |             |            |
|-------------|-------------|-------------|-------------|------------|
| 281,93      | 282,35      | 283,12,7,5  | 284,53      | 285,10,7,5 |
| 286,69      | 287,71      | 288,11,10,1 | 289,21      | 290,5,3,2  |
| 291,12,11,5 | 292,37      | 293,11,6,1  | 294,33      | 295,48     |
| 296,7,3,2   | 297,5       | 298,11,8,4  | 299,11,6,4  | 300,5      |
| 301,9,5,2   | 302,41      | 303,1       | 304,11,2,1  | 305,102    |
| 306,7,3,1   | 307,8,4,2   | 308,15      | 309,10,6,4  | 310,93     |
| 311,7,5,3   | 312,9,7,4   | 313,79      | 314,15      | 315,10,9,1 |
| 316,63      | 317,7,4,2   | 318,45      | 319,36      | 320,4,3,1  |
| 321,31      | 322,67      | 323,10,3,1  | 324,51      | 325,10,5,2 |
| 326,10,3,1  | 327,34      | 328,8,3,1   | 329,50      | 330,99     |
| 331,10,6,2  | 332,89      | 333,2       | 334,5,2,1   | 335,10,7,2 |
| 336,7,4,1   | 337,55      | 338,4,3,1   | 339,16,10,7 | 340,45     |
| 341,10,8,6  | 342,125     | 343,75      | 344,7,2,1   | 345,22     |
| 346,63      | 347,11,10,3 | 348,103     | 349,6,5,2   | 350,53     |
| 351,34      | 352,13,11,6 | 353,69      | 354,99      | 355,6,5,1  |
| 356,10,9,7  | 357,11,10,2 | 358,57      | 359,68      | 360,5,3,2  |
| 361,7,4,1   | 362,63      | 363,8,5,3   | 364,9       | 365,9,6,5  |
| 366,29      | 367,21      | 368,7,3,2   | 369,91      | 370,139    |
| 371,8,3,2   | 372,111     | 373,8,7,2   | 374,8,6,5   | 375,16     |
| 376,8,7,5   | 377,41      | 378,43      | 379,10,8,5  | 380,47     |
| 381,5,2,1   | 382,81      | 383,90      | 384,12,3,2  | 385,6      |
| 386,83      | 387,8,7,1   | 388,159     | 389,10,9,5  | 390,9      |
| 391,28      | 392,13,10,6 | 393,7       | 394,135     | 395,11,6,5 |
| 396,25      | 397,12,7,6  | 398,7,6,2   | 399,26      | 400,5,3,2  |
| 401,152     | 402,171     | 403,9,8,5   | 404,65      | 405,13,8,2 |
| 406,141     | 407,71      | 408,5,3,2   | 409,87      | 410,10,4,3 |
| 411,12,10,3 | 412,147     | 413,10,7,6  | 414,13      | 415,102    |
| 416,9,5,2   | 417,107     | 418,199     | 419,15,5,4  | 420,7      |
| 421,5,4,2   | 422,149     | 423,25      | 424,9,7,2   | 425,12     |
| 426,63      | 427,11,6,5  | 428,105     | 429,10,8,7  | 430,14,6,1 |
| 431,120     | 432,13,4,3  | 433,33      | 434,12,11,5 | 435,12,9,5 |
| 436,165     | 437,6,2,1   | 438,65      | 439,49      | 440,4,3,1  |
| 441,7       | 442,7,5,2   | 443,10,6,1  | 444,81      | 445,7,6,4  |
| 446,105     | 447,73      | 448,11,6,4  | 449,134     | 450,47     |
| 451,16,10,1 | 452,6,5,4   | 453,15,6,4  | 454,8,6,1   | 455,38     |

|             |             |              |              |             |
|-------------|-------------|--------------|--------------|-------------|
| 456,18,9,6  | 457,16      | 458,203      | 459,13,5,2   | 460,19      |
| 461,7,6,1   | 462,73      | 463,93       | 464,19,18,13 | 465,31      |
| 466,14,11,6 | 467,11,6,1  | 468,27       | 469,9,5,2    | 470,9       |
| 471,1       | 472,11,3,2  | 473,200      | 474,191      | 475,9,8,4   |
| 476,9       | 477,16,15,7 | 478,121      | 479,104      | 480,15,9,6  |
| 481,138     | 482,9,6,5   | 483,9,6,4    | 484,105      | 485,17,16,6 |
| 486,81      | 487,94      | 488,4,3,1    | 489,83       | 490,219     |
| 491,11,6,3  | 492,7       | 493,10,5,3   | 494,17       | 495,76      |
| 496,16,5,2  | 497,78      | 498,155      | 499,11,6,5   | 500,27      |
| 501,5,4,2   | 502,8,5,4   | 503,3        | 504,15,14,6  | 505,156     |
| 506,23      | 507,13,6,3  | 508,9        | 509,8,7,3    | 510,69      |
| 511,10      | 512,8,5,2   | 513,26       | 514,67       | 515,14,7,4  |
| 516,21      | 517,12,10,2 | 518,33       | 519,79       | 520,15,11,2 |
| 521,32      | 522,39      | 523,13,6,2   | 524,167      | 525,6,4,1   |
| 526,97      | 527,47      | 528,11,6,2   | 529,42       | 530,10,7,3  |
| 531,10,5,4  | 532,1       | 533,4,3,2    | 534,161      | 535,8,6,2   |
| 536,7,5,3   | 537,94      | 538,195      | 539,10,5,4   | 540,9       |
| 541,13,10,4 | 542,8,6,1   | 543,16       | 544,8,3,1    | 545,122     |
| 546,8,2,1   | 547,13,7,4  | 548,10,5,3   | 549,16,4,3   | 550,193     |
| 551,135     | 552,19,16,9 | 553,39       | 554,10,8,7   | 555,10,9,4  |
| 556,153     | 557,7,6,5   | 558,73       | 559,34       | 560,11,9,6  |
| 561,71      | 562,11,4,2  | 563,14,7,3   | 564,163      | 565,11,6,1  |
| 566,153     | 567,28      | 568,15,7,6   | 569,77       | 570,67      |
| 571,10,5,2  | 572,12,8,1  | 573,10,6,4   | 574,13       | 575,146     |
| 576,13,4,3  | 577,25      | 578,23,22,16 | 579,12,9,7   | 580,237     |

Table 6.36-7 Low-Weight Binary Irreducible Polynomials

4. Only when START and DMAEN (CRYPTO\_ECC\_CTL[0] and [7]) are assigned to 1 simultaneously, ECC DMA mode will be active.
5. When ECC engine is active (i.e., BUSY is 1 and DMABUSY (CRYPTO\_ECC\_STS[1]) is 0), user can't modify all input data registers (CRYPTO\_ECC\_X1\_00 ~ CRYPTO\_ECC\_K\_17).
6. If user wants to stop ECC accelerator, please configures the STOP (CRYPTO\_ECC\_CTL[1]) to 1. Note that: To avoid the transmission error of the next operation, BUSY signal will not be cleared immediately until the action of DMA is done.
7. The modulus operation not support for binary field.
8. The input data of modulus multiplication operation and division operation for PF must be less than N.
9. K is private key, so this register is write only.

The following describes the method of application about key pair generation, ECDSA and ECDH.

### Key Pair Generation

Public key generation function:  $Q = dG \pmod{N}$

1. Write the curve parameter A, B, N, and curve length M to corresponding registers according to Table 6.36-5.
2. Write the point G(x, y) to X1, Y1 registers according to Table 6.36-5.
3. Write the private key d to K register according to Table 6.36-5.
4. Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 00
5. Set FSEL(CRYPTO\_ECC\_CTL[8]) according to used curve of prime field or binary field
6. Set START(CRYPTO\_ECC\_CTL[0]) to 1
7. Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
8. Read public key Q from X1, Y1 registers

### Elliptic Curve Digital Signature Algorithm (ECDSA)

#### **ECDSA signature generation steps:**

1. Calculate  $e = \text{HASH}(m)$ , where HASH is a cryptographic hashing algorithm, (i.e. SHA-1)
  - 1) Use SHA to calculate e
2. Select a random integer k form  $[1, n-1]$ 
  - 1) Note that n is order, not prime modulus or irreducible polynomial function
3. Compute  $r = x_1 \pmod{n}$ , where  $(x_1, y_1) = k * G$ . If  $r = 0$ , go to step 2
  - 1) Write the curve parameter A, B, N and curve length M to corresponding registers according to Table 6.36-5
  - 2) Write the prime modulus or irreducible polynomial function to N registers according to Table 6.36-5
  - 3) Write the point G(x, y) to X1, Y1 registers according to Table 6.36-5
  - 4) Write the random integer k to K register according to Table 6.36-5
  - 5) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 00
  - 6) Set FSEL(CRYPTO\_ECC\_CTL[8]) according to used curve of prime field or binary field
  - 7) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 8) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 9) Write the curve order and curve length to N, M registers according to Table 6.36-5
  - 10) Write 0x0 to Y1 registers
  - 11) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 12) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 10
  - 13) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 14) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 15) Read X1 registers to get r
4. Compute  $s = k - 1 \times (e + d \times r) \pmod{n}$ . If  $s = 0$ , go to step 2
  - 1) Write the curve order to N registers according to Table 6.36-5

- 2) Write the random integer k to X1 registers according to Table 6.36-5
  - 3) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 4) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 00
  - 5) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 6) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 7) Read X1 registers to get k-1
  - 8) Write the curve order and curve length to N, M registers according to Table 6.36-5
  - 9) Write r, d to X1, Y1 registers
  - 10) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 11) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 01
  - 12) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 13) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 14) Write the curve order to N registers according to Table 6.36-5
  - 15) Write e to Y1 registers
  - 16) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 17) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 10
  - 18) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 19) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 20) Write the curve order and curve length to N, M registers according to Table 6.36-5
  - 21) Write k-1 to Y1 registers
  - 22) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 23) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 01
  - 24) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 25) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 26) Read X1 registers to get s
5. The signature is the pair (r, s)

**ECDSA signature verification steps:**

1. Verify that r and s are integers in the interval [1, n-1]. If not, the signature is invalid
2. Compute e = HASH (m), where HASH is the hashing algorithm in signature generation
  - 1) Use SHA to calculate e
3. Compute w = s  $\text{mod } n$ 
  - 1) Write the curve order to N registers according to Table 6.36-5
  - 2) Write s to X1 registers according to Table 6.36-5
  - 3) Write 0x1 to Y1 registers according to Table 6.36-5
  - 4) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 5) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 00
  - 6) Set FSEL(CRYPTO\_ECC\_CTL[8]) according to used curve of prime field or binary field
  - 7) Set START(CRYPTO\_ECC\_CTL[0]) to 1

- 8) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
- 9) Read X1 registers to get w
4. Compute  $u_1 = e \times w \pmod n$  and  $u_2 = r \times w \pmod n$ 
  - 1) Write the curve order and curve length to N, M registers according to Table 6.36-5
  - 2) Write e, w to X1, Y1 registers
  - 3) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 4) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 01
  - 5) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 6) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 7) Read X1 registers to get  $u_1$
  - 8) Write the curve order and curve length to N, M registers according to Table 6.36-5
  - 9) Write r, w to X1, Y1 registers
  - 10) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
  - 11) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 01
  - 12) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 13) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 14) Read X1 registers to get  $u_2$
5. Compute  $X' (x_1', y_1') = u_1 * G + u_2 * Q$ 
  - 1) Write the curve parameter A, B, N, and curve length M to corresponding registers according to Table 6.36-5
  - 2) Write the point G(x, y) to X1, Y1 registers
  - 3) Write  $u_1$  to K registers
  - 4) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 00
  - 5) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 6) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 7) Read X1, Y1 registers to get  $u_1 * G$
  - 8) Write the curve parameter A, B, N, and curve length M to corresponding registers according to Table 6.36-5
  - 9) Write the public key Q(x,y) to X1, Y1 registers
  - 10) Write  $u_2$  to K registers
  - 11) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 00
  - 12) Set START(CRYPTO\_ECC\_CTL[0]) to 1
  - 13) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
  - 14) Write the curve parameter A, B, N, and curve length M to corresponding registers according to Table 6.36-5
  - 15) Write the result data  $u_1 * G$  to X2, Y2 registers
  - 16) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 10
  - 17) Set START(CRYPTO\_ECC\_CTL[0]) to 1

- 18) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
- 19) Read X1, Y1 registers to get X'(x1', y1')
- 20) Write the curve order and curve length to N, M registers according to Table 6.36-5
- 21) Write x1' to X1 registers
- 22) Write 0x0 to Y1 registers
- 23) Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 01
- 24) Set MOPOP(CRYPTO\_ECC\_CTL[12:11]) to 10
- 25) Set START(CRYPTO\_ECC\_CTL[0]) to 1
- 26) Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
- 27) Read X1 registers to get x1' (mod n)
6. The signature is valid if  $x1' = r$ , otherwise it is invalid.

#### Elliptic Curve Diffie-Hellman

Share secret generation function: Z is the x-coordinate of Q where  $Q = dG \pmod{N}$

1. Write the curve parameter A, B, N, and curve length M to corresponding registers according to Table 6.36-5.
2. Write the public key of receiving party G(x, y) to X1, Y1 registers according to Table 6.36-5.
3. Write (cofactor h \* my private key d) to K register according to Table 6.36-5.
  - 1) h=1 in P-192, P-224, P-256, P-384 and P-521
  - 2) h=2 in B-163, B-233, B-283, B-409, B-571 and K-163
  - 3) h=4 in K-233, K-283, K-409 and K-571
4. Set ECCOP(CRYPTO\_ECC\_CTL[10:9]) to 00
5. Set FSEL(CRYPTO\_ECC\_CTL[8]) according to used curve of prime field or binary field
6. Set START(CRYPTO\_ECC\_CTL[0]) to 1
7. Wait for BUSY(CRYPTO\_ECC\_STS[0]) be cleared
8. Read public key Q from X1, Y1 registers

Hash-based key derivation function: DerivedKeyingMaterial = KDF(Z, OtherInput)

#### **Step1 For i = 1 to reps, where reps = ceil( (the length of Z, OtherInput)/hash length )**

1. Write the curve parameter A, B, N, and curve length M to corresponding registers according to Table 6.36-5.
2. Write the public key of receiving party G(x, y) to X1, Y1 registers according to Table 6.36-5.

#### **Step 2 Return DerivedKeyingMaterial = Hash<sub>1</sub> || Hash<sub>2</sub> || ... || Hash<sub>reps</sub>**

#### Note:

1. the details of OtherInput please refer to the page 46 in NIST SP 800-56A, recommendation for Pair-Wise Key Establishment Schemes Using Discrete Logarithm Cryptography ([http://csrc.nist.gov/groups/ST/toolkit/documents/SP800-56Arev1\\_3-8-07.pdf](http://csrc.nist.gov/groups/ST/toolkit/documents/SP800-56Arev1_3-8-07.pdf))
2. the details of cofactor please refer to “RECOMMENDED ELLIPTIC CURVES FOR FEDERAL GOVERNMENT USE” (<http://csrc.nist.gov/groups/ST/toolkit/documents/dss/NISTReCur.pdf>)

### 6.36.6 Register Map

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

| Register                    | Offset          | R/W | Description                                                                  | Reset Value |
|-----------------------------|-----------------|-----|------------------------------------------------------------------------------|-------------|
| <b>CRYPTO Base Address:</b> |                 |     |                                                                              |             |
| CRYPTO_BA = 0x5008_0000     |                 |     |                                                                              |             |
| 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_PRNG_CTL             | CRYPTO_BA+0x008 | R/W | PRNG Control Register                                                        | 0x0000_0000 |
| CRYPTO_PRNG_SEED            | CRYPTO_BA+0x00C | W   | Seed for PRNG                                                                | Undefined   |
| CRYPTO_PRNG_KEY0            | CRYPTO_BA+0x010 | R   | PRNG Generated Key0                                                          | Undefined   |
| CRYPTO_PRNG_KEY1            | CRYPTO_BA+0x014 | R   | PRNG Generated Key1                                                          | Undefined   |
| CRYPTO_PRNG_KEY2            | CRYPTO_BA+0x018 | R   | PRNG Generated Key2                                                          | Undefined   |
| CRYPTO_PRNG_KEY3            | CRYPTO_BA+0x01C | R   | PRNG Generated Key3                                                          | Undefined   |
| CRYPTO_PRNG_KEY4            | CRYPTO_BA+0x020 | R   | PRNG Generated Key4                                                          | Undefined   |
| CRYPTO_PRNG_KEY5            | CRYPTO_BA+0x024 | R   | PRNG Generated Key5                                                          | Undefined   |
| CRYPTO_PRNG_KEY6            | CRYPTO_BA+0x028 | R   | PRNG Generated Key6                                                          | Undefined   |
| CRYPTO_PRNG_KEY7            | CRYPTO_BA+0x02C | R   | PRNG Generated Key7                                                          | Undefined   |
| 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_TDES_FDBCK_H         | CRYPTO_BA+0x060 | R   | TDES/DES Engine Output Feedback High Word Data after Cryptographic Operation | 0x0000_0000 |
| CRYPTO_TDES_FDBCK_L         | CRYPTO_BA+0x064 | R   | TDES/DES Engine Output Feedback Low Word 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_AES0_KEY0            | CRYPTO_BA+0x110 | R/W | AES Key Word 0 Register for Channel 0                                        | 0x0000_0000 |
| CRYPTO_AES0_KEY1            | CRYPTO_BA+0x114 | R/W | AES Key Word 1 Register for Channel 0                                        | 0x0000_0000 |
| CRYPTO_AES0_KEY2            | CRYPTO_BA+0x118 | R/W | AES Key Word 2 Register for Channel 0                                        | 0x0000_0000 |
| CRYPTO_AES0_KEY3            | CRYPTO_BA+0x11C | R/W | AES Key Word 3 Register for Channel 0                                        | 0x0000_0000 |
| CRYPTO_AES0_KEY4            | CRYPTO_BA+0x120 | R/W | AES Key Word 4 Register for Channel 0                                        | 0x0000_0000 |
| CRYPTO_AES0_KEY5            | CRYPTO_BA+0x124 | R/W | AES Key Word 5 Register for Channel 0                                        | 0x0000_0000 |

|                          |                 |     |                                                    |             |
|--------------------------|-----------------|-----|----------------------------------------------------|-------------|
| <b>CRYPTO_AES0_KEY6</b>  | CRYPTO_BA+0x128 | R/W | AES Key Word 6 Register for Channel 0              | 0x0000_0000 |
| <b>CRYPTO_AES0_KEY7</b>  | CRYPTO_BA+0x12C | R/W | AES Key Word 7 Register for Channel 0              | 0x0000_0000 |
| <b>CRYPTO_AES0_IV0</b>   | CRYPTO_BA+0x130 | R/W | AES Initial Vector Word 0 Register for Channel 0   | 0x0000_0000 |
| <b>CRYPTO_AES0_IV1</b>   | CRYPTO_BA+0x134 | R/W | AES Initial Vector Word 1 Register for Channel 0   | 0x0000_0000 |
| <b>CRYPTO_AES0_IV2</b>   | CRYPTO_BA+0x138 | R/W | AES Initial Vector Word 2 Register for Channel 0   | 0x0000_0000 |
| <b>CRYPTO_AES0_IV3</b>   | CRYPTO_BA+0x13C | R/W | AES Initial Vector Word 3 Register for Channel 0   | 0x0000_0000 |
| <b>CRYPTO_AES0_SADDR</b> | CRYPTO_BA+0x140 | R/W | AES DMA Source Address Register for Channel 0      | 0x0000_0000 |
| <b>CRYPTO_AES0_DADDR</b> | CRYPTO_BA+0x144 | R/W | AES DMA Destination Address Register for Channel 0 | 0x0000_0000 |
| <b>CRYPTO_AES0_CNT</b>   | CRYPTO_BA+0x148 | R/W | AES Byte Count Register for Channel 0              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY0</b>  | CRYPTO_BA+0x14C | R/W | AES Key Word 0 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY1</b>  | CRYPTO_BA+0x150 | R/W | AES Key Word 1 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY2</b>  | CRYPTO_BA+0x154 | R/W | AES Key Word 2 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY3</b>  | CRYPTO_BA+0x158 | R/W | AES Key Word 3 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY4</b>  | CRYPTO_BA+0x15C | R/W | AES Key Word 4 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY5</b>  | CRYPTO_BA+0x160 | R/W | AES Key Word 5 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY6</b>  | CRYPTO_BA+0x164 | R/W | AES Key Word 6 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_KEY7</b>  | CRYPTO_BA+0x168 | R/W | AES Key Word 7 Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES1_IV0</b>   | CRYPTO_BA+0x16C | R/W | AES Initial Vector Word 0 Register for Channel 1   | 0x0000_0000 |
| <b>CRYPTO_AES1_IV1</b>   | CRYPTO_BA+0x170 | R/W | AES Initial Vector Word 1 Register for Channel 1   | 0x0000_0000 |
| <b>CRYPTO_AES1_IV2</b>   | CRYPTO_BA+0x174 | R/W | AES Initial Vector Word 2 Register for Channel 1   | 0x0000_0000 |
| <b>CRYPTO_AES1_IV3</b>   | CRYPTO_BA+0x178 | R/W | AES Initial Vector Word 3 Register for Channel 1   | 0x0000_0000 |
| <b>CRYPTO_AES1_SADDR</b> | CRYPTO_BA+0x17C | R/W | AES DMA Source Address Register for Channel 1      | 0x0000_0000 |
| <b>CRYPTO_AES1_DADDR</b> | CRYPTO_BA+0x180 | R/W | AES DMA Destination Address Register for Channel 1 | 0x0000_0000 |
| <b>CRYPTO_AES1_CNT</b>   | CRYPTO_BA+0x184 | R/W | AES Byte Count Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY0</b>  | CRYPTO_BA+0x188 | R/W | AES Key Word 0 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY1</b>  | CRYPTO_BA+0x18C | R/W | AES Key Word 1 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY2</b>  | CRYPTO_BA+0x190 | R/W | AES Key Word 2 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY3</b>  | CRYPTO_BA+0x194 | R/W | AES Key Word 3 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY4</b>  | CRYPTO_BA+0x198 | R/W | AES Key Word 4 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY5</b>  | CRYPTO_BA+0x19C | R/W | AES Key Word 5 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY6</b>  | CRYPTO_BA+0x1A0 | R/W | AES Key Word 6 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY7</b>  | CRYPTO_BA+0x1A4 | R/W | AES Key Word 7 Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_AES2_IV0</b>   | CRYPTO_BA+0x1A8 | R/W | AES Initial Vector Word 0 Register for Channel 2   | 0x0000_0000 |
| <b>CRYPTO_AES2_IV1</b>   | CRYPTO_BA+0x1AC | R/W | AES Initial Vector Word 1 Register for Channel 2   | 0x0000_0000 |

|                            |                 |     |                                                          |             |
|----------------------------|-----------------|-----|----------------------------------------------------------|-------------|
| <b>CRYPTO_AES2_IV2</b>     | CRYPTO_BA+0x1B0 | R/W | AES Initial Vector Word 2 Register for Channel 2         | 0x0000_0000 |
| <b>CRYPTO_AES2_IV3</b>     | CRYPTO_BA+0x1B4 | R/W | AES Initial Vector Word 3 Register for Channel 2         | 0x0000_0000 |
| <b>CRYPTO_AES2_SADDR</b>   | CRYPTO_BA+0x1B8 | R/W | AES DMA Source Address Register for Channel 2            | 0x0000_0000 |
| <b>CRYPTO_AES2_DADDR</b>   | CRYPTO_BA+0x1BC | R/W | AES DMA Destination Address Register for Channel 2       | 0x0000_0000 |
| <b>CRYPTO_AES2_CNT</b>     | CRYPTO_BA+0x1C0 | R/W | AES Byte Count Register for Channel 2                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY0</b>    | CRYPTO_BA+0x1C4 | R/W | AES Key Word 0 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY1</b>    | CRYPTO_BA+0x1C8 | R/W | AES Key Word 1 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY2</b>    | CRYPTO_BA+0x1CC | R/W | AES Key Word 2 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY3</b>    | CRYPTO_BA+0x1D0 | R/W | AES Key Word 3 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY4</b>    | CRYPTO_BA+0x1D4 | R/W | AES Key Word 4 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY5</b>    | CRYPTO_BA+0x1D8 | R/W | AES Key Word 5 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY6</b>    | CRYPTO_BA+0x1DC | R/W | AES Key Word 6 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY7</b>    | CRYPTO_BA+0x1E0 | R/W | AES Key Word 7 Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_AES3_IV0</b>     | CRYPTO_BA+0x1E4 | R/W | AES Initial Vector Word 0 Register for Channel 3         | 0x0000_0000 |
| <b>CRYPTO_AES3_IV1</b>     | CRYPTO_BA+0x1E8 | R/W | AES Initial Vector Word 1 Register for Channel 3         | 0x0000_0000 |
| <b>CRYPTO_AES3_IV2</b>     | CRYPTO_BA+0x1EC | R/W | AES Initial Vector Word 2 Register for Channel 3         | 0x0000_0000 |
| <b>CRYPTO_AES3_IV3</b>     | CRYPTO_BA+0x1F0 | R/W | AES Initial Vector Word 3 Register for Channel 3         | 0x0000_0000 |
| <b>CRYPTO_AES3_SADDR</b>   | CRYPTO_BA+0x1F4 | R/W | AES DMA Source Address Register for Channel 3            | 0x0000_0000 |
| <b>CRYPTO_AES3_DADDR</b>   | CRYPTO_BA+0x1F8 | R/W | AES DMA Destination Address Register for Channel 3       | 0x0000_0000 |
| <b>CRYPTO_AES3_CNT</b>     | CRYPTO_BA+0x1FC | R/W | AES Byte Count Register for Channel 3                    | 0x0000_0000 |
| <b>CRYPTO_TDES_CTL</b>     | CRYPTO_BA+0x200 | R/W | TDES/DES Control Register                                | 0x0000_0000 |
| <b>CRYPTO_TDES_STS</b>     | CRYPTO_BA+0x204 | R   | TDES/DES Engine Flag                                     | 0x0001_0100 |
| <b>CRYPTO_TDES0_KEY1_H</b> | CRYPTO_BA+0x208 | R/W | TDES/DES Key 1 High Word Register for Channel 0          | 0x0000_0000 |
| <b>CRYPTO_TDES0_KEY1_L</b> | CRYPTO_BA+0x20C | R/W | TDES/DES Key 1 Low Word Register for Channel 0           | 0x0000_0000 |
| <b>CRYPTO_TDES0_KEY2_H</b> | CRYPTO_BA+0x210 | R/W | TDES Key 2 High Word Register for Channel 0              | 0x0000_0000 |
| <b>CRYPTO_TDES0_KEY2_L</b> | CRYPTO_BA+0x214 | R/W | TDES Key 2 Low Word Register for Channel 0               | 0x0000_0000 |
| <b>CRYPTO_TDES0_KEY3_H</b> | CRYPTO_BA+0x218 | R/W | TDES Key 3 High Word Register for Channel 0              | 0x0000_0000 |
| <b>CRYPTO_TDES0_KEY3_L</b> | CRYPTO_BA+0x21C | R/W | TDES Key 3 Low Word Register for Channel 0               | 0x0000_0000 |
| <b>CRYPTO_TDES0_IVH</b>    | CRYPTO_BA+0x220 | R/W | TDES/DES Initial Vector High Word Register for Channel 0 | 0x0000_0000 |

|                            |                 |     |                                                          |             |
|----------------------------|-----------------|-----|----------------------------------------------------------|-------------|
| <b>CRYPTO_TDES0_IVL</b>    | CRYPTO_BA+0x224 | R/W | TDES/DES Initial Vector Low Word Register for Channel 0  | 0x0000_0000 |
| <b>CRYPTO_TDES0_SADD R</b> | CRYPTO_BA+0x228 | R/W | TDES/DES DMA Source Address Register for Channel 0       | 0x0000_0000 |
| <b>CRYPTO_TDES0_DADD R</b> | CRYPTO_BA+0x22C | R/W | TDES/DES DMA Destination Address Register for Channel 0  | 0x0000_0000 |
| <b>CRYPTO_TDES0_CNT</b>    | CRYPTO_BA+0x230 | R/W | TDES/DES Byte Count Register for Channel 0               | 0x0000_0000 |
| <b>CRYPTO_TDES_DATIN</b>   | CRYPTO_BA+0x234 | R/W | TDES/DES Engine Input data Word Register                 | 0x0000_0000 |
| <b>CRYPTO_TDES_DATOUT</b>  | CRYPTO_BA+0x238 | R   | TDES/DES Engine Output data Word Register                | 0x0000_0000 |
| <b>CRYPTO_TDES1_KEY1 H</b> | CRYPTO_BA+0x248 | R/W | TDES/DES Key 1 High Word Register for Channel 1          | 0x0000_0000 |
| <b>CRYPTO_TDES1_KEY1 L</b> | CRYPTO_BA+0x24C | R/W | TDES/DES Key 1 Low Word Register for Channel 1           | 0x0000_0000 |
| <b>CRYPTO_TDES1_KEY2 H</b> | CRYPTO_BA+0x250 | R/W | TDES Key 2 High Word Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_TDES1_KEY2 L</b> | CRYPTO_BA+0x254 | R/W | TDES Key 2 Low Word Register for Channel 1               | 0x0000_0000 |
| <b>CRYPTO_TDES1_KEY3 H</b> | CRYPTO_BA+0x258 | R/W | TDES Key 3 High Word Register for Channel 1              | 0x0000_0000 |
| <b>CRYPTO_TDES1_KEY3 L</b> | CRYPTO_BA+0x25C | R/W | TDES Key 3 Low Word Register for Channel 1               | 0x0000_0000 |
| <b>CRYPTO_TDES1_IVH</b>    | CRYPTO_BA+0x260 | R/W | TDES/DES Initial Vector High Word Register for Channel 1 | 0x0000_0000 |
| <b>CRYPTO_TDES1_IVL</b>    | CRYPTO_BA+0x264 | R/W | TDES/DES Initial Vector Low Word Register for Channel 1  | 0x0000_0000 |
| <b>CRYPTO_TDES1_SADD R</b> | CRYPTO_BA+0x268 | R/W | TDES/DES DMA Source Address Register for Channel 1       | 0x0000_0000 |
| <b>CRYPTO_TDES1_DADD R</b> | CRYPTO_BA+0x26C | R/W | TDES/DES DMA Destination Address Register for Channel 1  | 0x0000_0000 |
| <b>CRYPTO_TDES1_CNT</b>    | CRYPTO_BA+0x270 | R/W | TDES/DES Byte Count Register for Channel 1               | 0x0000_0000 |
| <b>CRYPTO_TDES2_KEY1 H</b> | CRYPTO_BA+0x288 | R/W | TDES/DES Key 1 High Word Register for Channel 2          | 0x0000_0000 |
| <b>CRYPTO_TDES2_KEY1 L</b> | CRYPTO_BA+0x28C | R/W | TDES/DES Key 1 Low Word Register for Channel 2           | 0x0000_0000 |
| <b>CRYPTO_TDES2_KEY2 H</b> | CRYPTO_BA+0x290 | R/W | TDES Key 2 High Word Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_TDES2_KEY2 L</b> | CRYPTO_BA+0x294 | R/W | TDES Key 2 Low Word Register for Channel 2               | 0x0000_0000 |
| <b>CRYPTO_TDES2_KEY3 H</b> | CRYPTO_BA+0x298 | R/W | TDES Key 3 High Word Register for Channel 2              | 0x0000_0000 |
| <b>CRYPTO_TDES2_KEY3 L</b> | CRYPTO_BA+0x29C | R/W | TDES Key 3 Low Word Register for Channel 2               | 0x0000_0000 |
| <b>CRYPTO_TDES2_IVH</b>    | CRYPTO_BA+0x2A0 | R/W | TDES/DES Initial Vector High Word Register for Channel 2 | 0x0000_0000 |

|                            |                 |     |                                                          |             |
|----------------------------|-----------------|-----|----------------------------------------------------------|-------------|
| <b>CRYPTO_TDES2_IVL</b>    | CRYPTO_BA+0x2A4 | R/W | TDES/DES Initial Vector Low Word Register for Channel 2  | 0x0000_0000 |
| <b>CRYPTO_TDES2_SADD_R</b> | CRYPTO_BA+0x2A8 | R/W | TDES/DES DMA Source Address Register for Channel 2       | 0x0000_0000 |
| <b>CRYPTO_TDES2_DADD_R</b> | CRYPTO_BA+0x2AC | R/W | TDES/DES DMA Destination Address Register for Channel 2  | 0x0000_0000 |
| <b>CRYPTO_TDES2_CNT</b>    | CRYPTO_BA+0x2B0 | R/W | TDES/DES Byte Count Register for Channel 2               | 0x0000_0000 |
| <b>CRYPTO_TDES3_KEY1_H</b> | CRYPTO_BA+0x2C8 | R/W | TDES/DES Key 1 High Word Register for Channel 3          | 0x0000_0000 |
| <b>CRYPTO_TDES3_KEY1_L</b> | CRYPTO_BA+0x2CC | R/W | TDES/DES Key 1 Low Word Register for Channel 3           | 0x0000_0000 |
| <b>CRYPTO_TDES3_KEY2_H</b> | CRYPTO_BA+0x2D0 | R/W | TDES Key 2 High Word Register for Channel 3              | 0x0000_0000 |
| <b>CRYPTO_TDES3_KEY2_L</b> | CRYPTO_BA+0x2D4 | R/W | TDES Key 2 Low Word Register for Channel 3               | 0x0000_0000 |
| <b>CRYPTO_TDES3_KEY3_H</b> | CRYPTO_BA+0x2D8 | R/W | TDES Key 3 High Word Register for Channel 3              | 0x0000_0000 |
| <b>CRYPTO_TDES3_KEY3_L</b> | CRYPTO_BA+0x2DC | R/W | TDES Key 3 Low Word Register for Channel 3               | 0x0000_0000 |
| <b>CRYPTO_TDES3_IVH</b>    | CRYPTO_BA+0x2E0 | R/W | TDES/DES Initial Vector High Word Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_TDES3_IVL</b>    | CRYPTO_BA+0x2E4 | R/W | TDES/DES Initial Vector Low Word Register for Channel 3  | 0x0000_0000 |
| <b>CRYPTO_TDES3_SADD_R</b> | CRYPTO_BA+0x2E8 | R/W | TDES/DES DMA Source Address Register for Channel 3       | 0x0000_0000 |
| <b>CRYPTO_TDES3_DADD_R</b> | CRYPTO_BA+0x2EC | R/W | TDES/DES DMA Destination Address Register for Channel 3  | 0x0000_0000 |
| <b>CRYPTO_TDES3_CNT</b>    | CRYPTO_BA+0x2F0 | R/W | TDES/DES Byte Count Register for Channel 3               | 0x0000_0000 |
| <b>CRYPTO_HMAC_CTL</b>     | CRYPTO_BA+0x300 | R/W | SHA/HMAC Control Register                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_STS</b>     | CRYPTO_BA+0x304 | R   | SHA/HMAC Status Flag                                     | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_0</b>  | CRYPTO_BA+0x308 | R   | SHA/HMAC Digest Message 0                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_1</b>  | CRYPTO_BA+0x30C | R   | SHA/HMAC Digest Message 1                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_2</b>  | CRYPTO_BA+0x310 | R   | SHA/HMAC Digest Message 2                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_3</b>  | CRYPTO_BA+0x314 | R   | SHA/HMAC Digest Message 3                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_4</b>  | CRYPTO_BA+0x318 | R   | SHA/HMAC Digest Message 4                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_5</b>  | CRYPTO_BA+0x31C | R   | SHA/HMAC Digest Message 5                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_6</b>  | CRYPTO_BA+0x320 | R   | SHA/HMAC Digest Message 6                                | 0x0000_0000 |
| <b>CRYPTO_HMAC_DGST_7</b>  | CRYPTO_BA+0x324 | R   | SHA/HMAC Digest Message 7                                | 0x0000_0000 |

|                     |                 |     |                                                       |             |
|---------------------|-----------------|-----|-------------------------------------------------------|-------------|
| CRYPTO_HMAC_DGST_8  | CRYPTO_BA+0x328 | R   | SHA/HMAC Digest Message 8                             | 0x0000_0000 |
| CRYPTO_HMAC_DGST_9  | CRYPTO_BA+0x32C | R   | SHA/HMAC Digest Message 9                             | 0x0000_0000 |
| CRYPTO_HMAC_DGST_10 | CRYPTO_BA+0x330 | R   | SHA/HMAC Digest Message 10                            | 0x0000_0000 |
| CRYPTO_HMAC_DGST_11 | CRYPTO_BA+0x334 | R   | SHA/HMAC Digest Message 11                            | 0x0000_0000 |
| CRYPTO_HMAC_DGST_12 | CRYPTO_BA+0x338 | R   | SHA/HMAC Digest Message 12                            | 0x0000_0000 |
| CRYPTO_HMAC_DGST_13 | CRYPTO_BA+0x33C | R   | SHA/HMAC Digest Message 13                            | 0x0000_0000 |
| CRYPTO_HMAC_DGST_14 | CRYPTO_BA+0x340 | R   | SHA/HMAC Digest Message 14                            | 0x0000_0000 |
| CRYPTO_HMAC_DGST_15 | CRYPTO_BA+0x344 | R   | SHA/HMAC Digest Message 15                            | 0x0000_0000 |
| CRYPTO_HMAC_KEYCNT  | CRYPTO_BA+0x348 | R/W | SHA/HMAC Key Byte Count Register                      | 0x0000_0000 |
| CRYPTO_HMAC_SADDR   | CRYPTO_BA+0x34C | R/W | SHA/HMAC DMA Source Address Register                  | 0x0000_0000 |
| CRYPTO_HMAC_DMACNT  | CRYPTO_BA+0x350 | R/W | SHA/HMAC Byte Count Register                          | 0x0000_0000 |
| CRYPTO_HMAC_DATIN   | CRYPTO_BA+0x354 | R/W | SHA/HMAC Engine Non-DMA Mode Data Input Port Register | 0x0000_0000 |
| CRYPTO_ECC_CTL      | CRYPTO_BA+0x800 | R/W | ECC Control Register                                  | 0x0000_0000 |
| CRYPTO_ECC_STS      | CRYPTO_BA+0x804 | R   | ECC Status Register                                   | 0x0000_0000 |
| CRYPTO_ECC_X1_00    | CRYPTO_BA+0x808 | R/W | ECC The X-coordinate word0 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_01    | CRYPTO_BA+0x80C | R/W | ECC The X-coordinate word1 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_02    | CRYPTO_BA+0x810 | R/W | ECC The X-coordinate word2 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_03    | CRYPTO_BA+0x814 | R/W | ECC The X-coordinate word3 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_04    | CRYPTO_BA+0x818 | R/W | ECC The X-coordinate word4 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_05    | CRYPTO_BA+0x81C | R/W | ECC The X-coordinate word5 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_06    | CRYPTO_BA+0x820 | R/W | ECC The X-coordinate word6 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_07    | CRYPTO_BA+0x824 | R/W | ECC The X-coordinate word7 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_08    | CRYPTO_BA+0x828 | R/W | ECC The X-coordinate word8 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_09    | CRYPTO_BA+0x82C | R/W | ECC The X-coordinate word9 of the first point         | 0x0000_0000 |
| CRYPTO_ECC_X1_10    | CRYPTO_BA+0x830 | R/W | ECC The X-coordinate word10 of the first point        | 0x0000_0000 |
| CRYPTO_ECC_X1_11    | CRYPTO_BA+0x834 | R/W | ECC The X-coordinate word11 of the first point        | 0x0000_0000 |
| CRYPTO_ECC_X1_12    | CRYPTO_BA+0x838 | R/W | ECC The X-coordinate word12 of the first point        | 0x0000_0000 |
| CRYPTO_ECC_X1_13    | CRYPTO_BA+0x83C | R/W | ECC The X-coordinate word13 of the first point        | 0x0000_0000 |
| CRYPTO_ECC_X1_14    | CRYPTO_BA+0x840 | R/W | ECC The X-coordinate word14 of the first point        | 0x0000_0000 |

|                  |                     |     |                                                 |             |
|------------------|---------------------|-----|-------------------------------------------------|-------------|
| CRYPTO_ECC_X1_15 | CRYPTO_BA+0x844     | R/W | ECC The X-coordinate word15 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_16 | CRYPTO_BA+0x848     | R/W | ECC The X-coordinate word16 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_17 | CRYPTO_BA+0x84C     | R/W | ECC The X-coordinate word17 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_00 | CRYPTO_BA+0x850     | R/W | ECC The Y-coordinate word0 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_01 | CRYPTO_BA+0x854     | R/W | ECC The Y-coordinate word1 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_02 | CRYPTO_BA+0x858     | R/W | ECC The Y-coordinate word2 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_03 | CRYPTO_BA+0x85C     | R/W | ECC The Y-coordinate word3 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_04 | CRYPTO_BA+0x860     | R/W | ECC The Y-coordinate word4 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_05 | CRYPTO_BA+0x864     | R/W | ECC The Y-coordinate word5 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_06 | CRYPTO_BA+0x868     | R/W | ECC The Y-coordinate word6 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_07 | CRYPTO_BA+0x86C     | R/W | ECC The Y-coordinate word7 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_08 | CRYPTO_BA+0x870     | R/W | ECC The Y-coordinate word8 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_09 | CRYPTO_BA+0x874     | R/W | ECC The Y-coordinate word9 of the first point   | 0x0000_0000 |
| CRYPTO_ECC_Y1_10 | CRYPTO_BA+0x878     | R/W | ECC The Y-coordinate word10 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_11 | CRYPTO_BA+0x87C     | R/W | ECC The Y-coordinate word11 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_12 | CRYPTO_BA+0x880     | R/W | ECC The Y-coordinate word12 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_13 | CRYPTO_BA+0x884     | R/W | ECC The Y-coordinate word13 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_14 | CRYPTO_BA+0x888     | R/W | ECC The Y-coordinate word14 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_15 | CRYPTO_BA+0x88C     | R/W | ECC The Y-coordinate word15 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_16 | CRYPTO_BA+0x890     | R/W | ECC The Y-coordinate word16 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_17 | CRYPTO_BA+0x894     | R/W | ECC The Y-coordinate word17 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X2_00 | CRYPTO_BA+0x898     | R/W | ECC The X-coordinate word0 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_01 | CRYPTO_BA+0x89C     | R/W | ECC The X-coordinate word1 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_02 | CRYPTO_BA+0x8A0     | R/W | ECC The X-coordinate word2 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_03 | CRYPTO_BA+0x8A4     | R/W | ECC The X-coordinate word3 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_04 | CRYPTO_BA+0x8A8     | R/W | ECC The X-coordinate word4 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_05 | CRYPTO_BA+0x8AC     | R/W | ECC The X-coordinate word5 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_06 | CRYPTO_BA+0x8B0     | R/W | ECC The X-coordinate word6 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_07 | CRYPTO_BA+0x8B4     | R/W | ECC The X-coordinate word7 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_08 | CRYPTO_BA+0x8B8     | R/W | ECC The X-coordinate word8 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_09 | CRYPTO_BA+0x8BC     | R/W | ECC The X-coordinate word9 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_10 | CRYPTO_BA+0x8C0     | R/W | ECC The X-coordinate word10 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_11 | CRYPTO_BA+0x8C4     | R/W | ECC The X-coordinate word11 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_12 | CRYPTO_BA+0x8C8     | R/W | ECC The X-coordinate word12 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_13 | CRYPTO_BA+0x8C<br>C | R/W | ECC The X-coordinate word13 of the second point | 0x0000_0000 |

|                         |                 |     |                                                  |             |
|-------------------------|-----------------|-----|--------------------------------------------------|-------------|
| <b>CRYPTO_ECC_X2_14</b> | CRYPTO_BA+0x8D0 | R/W | ECC The X-coordinate word14 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_X2_15</b> | CRYPTO_BA+0x8D4 | R/W | ECC The X-coordinate word15 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_X2_16</b> | CRYPTO_BA+0x8D8 | R/W | ECC The X-coordinate word16 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_X2_17</b> | CRYPTO_BA+0x8DC | R/W | ECC The X-coordinate word17 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_00</b> | CRYPTO_BA+0x8E0 | R/W | ECC The Y-coordinate word0 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_01</b> | CRYPTO_BA+0x8E4 | R/W | ECC The Y-coordinate word1 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_02</b> | CRYPTO_BA+0x8E8 | R/W | ECC The Y-coordinate word2 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_03</b> | CRYPTO_BA+0x8EC | R/W | ECC The Y-coordinate word3 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_04</b> | CRYPTO_BA+0x8F0 | R/W | ECC The Y-coordinate word4 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_05</b> | CRYPTO_BA+0x8F4 | R/W | ECC The Y-coordinate word5 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_06</b> | CRYPTO_BA+0x8F8 | R/W | ECC The Y-coordinate word6 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_07</b> | CRYPTO_BA+0x8FC | R/W | ECC The Y-coordinate word7 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_08</b> | CRYPTO_BA+0x900 | R/W | ECC The Y-coordinate word8 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_09</b> | CRYPTO_BA+0x904 | R/W | ECC The Y-coordinate word9 of the second point   | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_10</b> | CRYPTO_BA+0x908 | R/W | ECC The Y-coordinate word10 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_11</b> | CRYPTO_BA+0x90C | R/W | ECC The Y-coordinate word11 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_12</b> | CRYPTO_BA+0x910 | R/W | ECC The Y-coordinate word12 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_13</b> | CRYPTO_BA+0x914 | R/W | ECC The Y-coordinate word13 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_14</b> | CRYPTO_BA+0x918 | R/W | ECC The Y-coordinate word14 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_15</b> | CRYPTO_BA+0x91C | R/W | ECC The Y-coordinate word15 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_16</b> | CRYPTO_BA+0x920 | R/W | ECC The Y-coordinate word16 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_Y2_17</b> | CRYPTO_BA+0x924 | R/W | ECC The Y-coordinate word17 of the second point  | 0x0000_0000 |
| <b>CRYPTO_ECC_A_00</b>  | CRYPTO_BA+0x928 | R/W | ECC The parameter CURVEA word0 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_01</b>  | CRYPTO_BA+0x92C | R/W | ECC The parameter CURVEA word1 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_02</b>  | CRYPTO_BA+0x930 | R/W | ECC The parameter CURVEA word2 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_03</b>  | CRYPTO_BA+0x934 | R/W | ECC The parameter CURVEA word3 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_04</b>  | CRYPTO_BA+0x938 | R/W | ECC The parameter CURVEA word4 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_05</b>  | CRYPTO_BA+0x93C | R/W | ECC The parameter CURVEA word5 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_06</b>  | CRYPTO_BA+0x940 | R/W | ECC The parameter CURVEA word6 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_07</b>  | CRYPTO_BA+0x944 | R/W | ECC The parameter CURVEA word7 of elliptic curve | 0x0000_0000 |

|                        |                 |     |                                                   |             |
|------------------------|-----------------|-----|---------------------------------------------------|-------------|
| <b>CRYPTO_ECC_A_08</b> | CRYPTO_BA+0x948 | R/W | ECC The parameter CURVEA word8 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_A_09</b> | CRYPTO_BA+0x94C | R/W | ECC The parameter CURVEA word9 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_A_10</b> | CRYPTO_BA+0x950 | R/W | ECC The parameter CURVEA word10 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_11</b> | CRYPTO_BA+0x954 | R/W | ECC The parameter CURVEA word11 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_12</b> | CRYPTO_BA+0x958 | R/W | ECC The parameter CURVEA word12 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_13</b> | CRYPTO_BA+0x95C | R/W | ECC The parameter CURVEA word13 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_14</b> | CRYPTO_BA+0x960 | R/W | ECC The parameter CURVEA word14 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_15</b> | CRYPTO_BA+0x964 | R/W | ECC The parameter CURVEA word15 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_16</b> | CRYPTO_BA+0x968 | R/W | ECC The parameter CURVEA word16 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_A_17</b> | CRYPTO_BA+0x96C | R/W | ECC The parameter CURVEA word17 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_B_00</b> | CRYPTO_BA+0x970 | R/W | ECC The parameter CURVEB word0 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_01</b> | CRYPTO_BA+0x974 | R/W | ECC The parameter CURVEB word1 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_02</b> | CRYPTO_BA+0x978 | R/W | ECC The parameter CURVEB word2 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_03</b> | CRYPTO_BA+0x97C | R/W | ECC The parameter CURVEB word3 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_04</b> | CRYPTO_BA+0x980 | R/W | ECC The parameter CURVEB word4 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_05</b> | CRYPTO_BA+0x984 | R/W | ECC The parameter CURVEB word5 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_06</b> | CRYPTO_BA+0x988 | R/W | ECC The parameter CURVEB word6 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_07</b> | CRYPTO_BA+0x98C | R/W | ECC The parameter CURVEB word7 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_08</b> | CRYPTO_BA+0x990 | R/W | ECC The parameter CURVEB word8 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_09</b> | CRYPTO_BA+0x994 | R/W | ECC The parameter CURVEB word9 of elliptic curve  | 0x0000_0000 |
| <b>CRYPTO_ECC_B_10</b> | CRYPTO_BA+0x998 | R/W | ECC The parameter CURVEB word10 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_B_11</b> | CRYPTO_BA+0x99C | R/W | ECC The parameter CURVEB word11 of elliptic curve | 0x0000_0000 |
| <b>CRYPTO_ECC_B_12</b> | CRYPTO_BA+0x9A0 | R/W | ECC The parameter CURVEB word12 of elliptic curve | 0x0000_0000 |

|                 |                     |     |                                                   |             |
|-----------------|---------------------|-----|---------------------------------------------------|-------------|
| CRYPTO_ECC_B_13 | CRYPTO_BA+0x9A4     | R/W | ECC The parameter CURVEB word13 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_14 | CRYPTO_BA+0x9A8     | R/W | ECC The parameter CURVEB word14 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_15 | CRYPTO_BA+0x9AC     | R/W | ECC The parameter CURVEB word15 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_16 | CRYPTO_BA+0x9B0     | R/W | ECC The parameter CURVEB word16 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_17 | CRYPTO_BA+0x9B4     | R/W | ECC The parameter CURVEB word17 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_00 | CRYPTO_BA+0x9B8     | R/W | ECC The parameter CURVEN word0 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_01 | CRYPTO_BA+0x9BC     | R/W | ECC The parameter CURVEN word1 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_02 | CRYPTO_BA+0x9C0     | R/W | ECC The parameter CURVEN word2 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_03 | CRYPTO_BA+0x9C4     | R/W | ECC The parameter CURVEN word3 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_04 | CRYPTO_BA+0x9C8     | R/W | ECC The parameter CURVEN word4 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_05 | CRYPTO_BA+0x9C<br>C | R/W | ECC The parameter CURVEN word5 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_06 | CRYPTO_BA+0x9D0     | R/W | ECC The parameter CURVEN word6 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_07 | CRYPTO_BA+0x9D4     | R/W | ECC The parameter CURVEN word7 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_08 | CRYPTO_BA+0x9D8     | R/W | ECC The parameter CURVEN word8 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_09 | CRYPTO_BA+0x9D<br>C | R/W | ECC The parameter CURVEN word9 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_10 | CRYPTO_BA+0x9E0     | R/W | ECC The parameter CURVEN word10 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_11 | CRYPTO_BA+0x9E4     | R/W | ECC The parameter CURVEN word11 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_12 | CRYPTO_BA+0x9E8     | R/W | ECC The parameter CURVEN word12 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_13 | CRYPTO_BA+0x9EC     | R/W | ECC The parameter CURVEN word13 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_14 | CRYPTO_BA+0x9F0     | R/W | ECC The parameter CURVEN word14 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_15 | CRYPTO_BA+0x9F4     | R/W | ECC The parameter CURVEN word15 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_16 | CRYPTO_BA+0x9F8     | R/W | ECC The parameter CURVEN word16 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_17 | CRYPTO_BA+0x9FC     | R/W | ECC The parameter CURVEN word17 of elliptic curve | 0x0000_0000 |

|                             |                 |     |                                                       |             |
|-----------------------------|-----------------|-----|-------------------------------------------------------|-------------|
| <b>CRYPTO_ECC_K_00</b>      | CRYPTO_BA+0xA00 | W   | ECC The scalar SCALARK word0 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_01</b>      | CRYPTO_BA+0xA04 | W   | ECC The scalar SCALARK word1 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_02</b>      | CRYPTO_BA+0xA08 | W   | ECC The scalar SCALARK word2 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_03</b>      | CRYPTO_BA+0xA0C | W   | ECC The scalar SCALARK word3 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_04</b>      | CRYPTO_BA+0xA10 | W   | ECC The scalar SCALARK word4 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_05</b>      | CRYPTO_BA+0xA14 | W   | ECC The scalar SCALARK word5 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_06</b>      | CRYPTO_BA+0xA18 | W   | ECC The scalar SCALARK word6 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_07</b>      | CRYPTO_BA+0xA1C | W   | ECC The scalar SCALARK word7 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_08</b>      | CRYPTO_BA+0xA20 | W   | ECC The scalar SCALARK word8 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_09</b>      | CRYPTO_BA+0xA24 | W   | ECC The scalar SCALARK word9 of point multiplication  | 0x0000_0000 |
| <b>CRYPTO_ECC_K_10</b>      | CRYPTO_BA+0xA28 | W   | ECC The scalar SCALARK word10 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_K_11</b>      | CRYPTO_BA+0xA2C | W   | ECC The scalar SCALARK word11 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_K_12</b>      | CRYPTO_BA+0xA30 | W   | ECC The scalar SCALARK word12 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_K_13</b>      | CRYPTO_BA+0xA34 | W   | ECC The scalar SCALARK word13 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_K_14</b>      | CRYPTO_BA+0xA38 | W   | ECC The scalar SCALARK word14 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_K_15</b>      | CRYPTO_BA+0xA3C | W   | ECC The scalar SCALARK word15 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_K_16</b>      | CRYPTO_BA+0xA40 | W   | ECC The scalar SCALARK word16 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_K_17</b>      | CRYPTO_BA+0xA44 | W   | ECC The scalar SCALARK word17 of point multiplication | 0x0000_0000 |
| <b>CRYPTO_ECC_SADDR</b>     | CRYPTO_BA+0xA48 | R/W | ECC DMA Source Address Register                       | 0x0000_0000 |
| <b>CRYPTO_ECC_DADDR</b>     | CRYPTO_BA+0xA4C | R/W | ECC DMA Destination Address Register                  | 0x0000_0000 |
| <b>CRYPTO_ECC_STARTREG</b>  | CRYPTO_BA+0xA50 | R/W | ECC Starting Address of Updated Registers             | 0x0000_0000 |
| <b>CRYPTO_ECC_WORDCOUNT</b> | CRYPTO_BA+0xA54 | R/W | ECC DMA Word Count                                    | 0x0000_0000 |

### 6.36.7 Register Description

#### 6.36.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 |  |  |  | 0x0000_0000 |

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

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [25]    | <b>HMACEIEN</b><br><b>SHA/HMAC Error Interrupt Enable Bit</b><br>0 = SHA/HMAC error interrupt flag Disabled.<br>1 = SHA/HMAC error interrupt flag Enabled.                                                                                                                                                                                                         |
| [24]    | <b>HMACIEN</b><br><b>SHA/HMAC Interrupt Enable Bit</b><br>0 = SHA/HMAC interrupt Disabled.<br>1 = SHA/HMAC interrupt Enabled.<br><b>Note:</b> In DMA mode, an interrupt will be triggered when amount of data set in SHA_DMA_CNT is fed into the SHA/HMAC engine. In Non-DMA mode, an interrupt will be triggered when the SHA/HMAC engine finishes the operation. |
| [23]    | <b>ECCEIEN</b><br><b>ECC Error Interrupt Enable Bit</b><br>0 = ECC error interrupt flag Disabled.<br>1 = ECC error interrupt flag Enabled.                                                                                                                                                                                                                         |
| [22]    | <b>ECCIEN</b><br><b>ECC Interrupt Enable Bit</b><br>0 = ECC interrupt Disabled.<br>1 = ECC interrupt Enabled.<br><b>Note:</b> In DMA mode, an interrupt will be triggered when amount of data set in ECC_DMA_CNT is fed into the ECC engine. In Non-DMA mode, an interrupt will be triggered when the ECC engine finishes the operation.                           |
| [21:17] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [16]    | <b>PRNGIEN</b><br><b>PRNG Interrupt Enable Bit</b><br>0 = PRNG interrupt Disabled.<br>1 = PRNG interrupt Enabled.                                                                                                                                                                                                                                                  |
| [15:10] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                       |

|       |          |                                                                                                                                                                                                                                                                                                                                           |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9]   | TDESEIEN | <b>TDES/DES Error Flag Enable Bit</b><br>0 = TDES/DES error interrupt flag Disabled.<br>1 = TDES/DES error interrupt flag Enabled.                                                                                                                                                                                                        |
| [8]   | TDESIEN  | <b>TDES/DES Interrupt Enable Bit</b><br>0 = TDES/DES interrupt Disabled.<br>1 = TDES/DES interrupt Enabled.<br><b>Note:</b> In DMA mode, an interrupt will be triggered when amount of data set in TDES_DMA_CNT is fed into the TDES engine. In Non-DMA mode, an interrupt will be triggered when the TDES engine finishes the operation. |
| [7:2] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                 |
| [1]   | AESEIEN  | <b>AES Error Flag Enable Bit</b><br>0 = AES error interrupt flag Disabled.<br>1 = AES error interrupt flag Enabled.                                                                                                                                                                                                                       |
| [0]   | AESIEN   | <b>AES Interrupt Enable Bit</b><br>0 = AES interrupt Disabled.<br>1 = AES interrupt Enabled.<br><b>Note:</b> In DMA mode, an interrupt will be triggered when amount of data set in AES_DMA_CNT is fed into the AES engine. 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+0x004 | R/W | Crypto Interrupt Flag |  |  | 0x0000_0000 |  |

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

| Bits    | Description                                                                                                                                                                                                                                                                                  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                 |
| [25]    | <b>HMACEIF</b><br><b>SHA/HMAC Error Flag</b><br>This register includes operating and setting error. The detail flag is shown in CRYPTO_HMAC_STS register.<br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No SHA/HMAC error.<br>1 = SHA/HMAC error interrupt. |
| [24]    | <b>HMACIF</b><br><b>SHA/HMAC Finish Interrupt Flag</b><br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No SHA/HMAC interrupt.<br>1 = SHA/HMAC operation done interrupt.                                                                                       |
| [23]    | <b>ECCEIF</b><br><b>ECC Error Flag</b><br>This register includes operating and setting error. The detail flag is shown in CRYPTO_ECC_STS register.<br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No ECC error.<br>1 = ECC error interrupt.                  |
| [22]    | <b>ECCIF</b><br><b>ECC Finish Interrupt Flag</b><br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No ECC interrupt.<br>1 = ECC operation done interrupt.                                                                                                       |
| [21:17] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                 |
| [16]    | <b>PRNGIF</b><br><b>PRNG Finish Interrupt Flag</b><br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No PRNG interrupt.<br>1 = PRNG key generation done interrupt.                                                                                              |
| [15:10] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                 |

|       |                 |                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9]   | <b>TDESEIF</b>  | <b>TDES/DES Error Flag</b><br>This bit includes the operating and setting error. The detailed flag is shown in the CRYPTO_TDES_STS register. This includes operating and setting error.<br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No TDES/DES error.<br>1 = TDES/DES encryption/decryption error interrupt. |
| [8]   | <b>TDESIF</b>   | <b>TDES/DES Finish Interrupt Flag</b><br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No TDES/DES interrupt.<br>1 = TDES/DES encryption/decryption done interrupt.                                                                                                                                                |
| [7:2] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                        |
| [1]   | <b>AESEIF</b>   | <b>AES Error Flag</b><br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No AES error.<br>1 = AES encryption/decryption error interrupt.                                                                                                                                                                             |
| [0]   | <b>AESIF</b>    | <b>AES Finish Interrupt Flag</b><br>This bit is cleared by writing 1, and it has no effect by writing 0.<br>0 = No AES interrupt.<br>1 = AES encryption/decryption done interrupt.                                                                                                                                                               |

## 6.36.7.2 PRNG Register

**PRNG Control Register (CRYPTO\_PRNG\_CTL)**

| Register        | Offset          | R/W | Description           | Reset Value |
|-----------------|-----------------|-----|-----------------------|-------------|
| CRYPTO_PRNG_CTL | CRYPTO_BA+0x008 | R/W | PRNG 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 |    |    |    | KEYSZ |    | SEEDRLD |    |
|          |    |    |    |       |    | START   |    |

| Bits   | Description     |                                                                                                                                                                                    |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | <b>Reserved</b> | Reserved.                                                                                                                                                                          |
| [8]    | <b>BUSY</b>     | <b>PRNG Busy (Read Only)</b><br>0 = PRNG engine is idle.<br>1 = Indicate that the PRNG engine is generating CRYPTO_PRNG_KEYx.                                                      |
| [7:4]  | <b>Reserved</b> | Reserved.                                                                                                                                                                          |
| [3:2]  | <b>KEYSZ</b>    | <b>PRNG Generate Key Size</b><br>00 = 64 bits.<br>01 = 128 bits.<br>10 = 192 bits.<br>11 = 256 bits.                                                                               |
| [1]    | <b>SEEDRLD</b>  | <b>Reload New Seed for PRNG Engine</b><br>0 = Generating key based on the current seed.<br>1 = Reload new seed.                                                                    |
| [0]    | <b>START</b>    | <b>Start PRNG Engine</b><br>0 = Stop PRNG engine.<br>1 = Generate new key and store the new key to register CRYPTO_PRNG_KEYx, which will be cleared when the new key is generated. |

**PRNG Seed Register (CRYPTO\_PRNG\_SEED)**

| Register         | Offset          | R/W | Description   | Reset Value |
|------------------|-----------------|-----|---------------|-------------|
| CRYPTO_PRNG_SEED | CRYPTO_BA+0x00C | W   | Seed for PRNG | Undefined   |

|      |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|
| 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        | Seed for PRNG (Write Only)<br>The bits store the seed for PRNG engine. |

**PRNG Key x Register (CRYPTO\_PRNG\_KEYx)**

| Register         | Offset          | R/W | Description         | Reset Value |
|------------------|-----------------|-----|---------------------|-------------|
| CRYPTO_PRNG_KEY0 | CRYPTO_BA+0x010 | R   | PRNG Generated Key0 | Undefined   |
| CRYPTO_PRNG_KEY1 | CRYPTO_BA+0x014 | R   | PRNG Generated Key1 | Undefined   |
| CRYPTO_PRNG_KEY2 | CRYPTO_BA+0x018 | R   | PRNG Generated Key2 | Undefined   |
| CRYPTO_PRNG_KEY3 | CRYPTO_BA+0x01C | R   | PRNG Generated Key3 | Undefined   |
| CRYPTO_PRNG_KEY4 | CRYPTO_BA+0x020 | R   | PRNG Generated Key4 | Undefined   |
| CRYPTO_PRNG_KEY5 | CRYPTO_BA+0x024 | R   | PRNG Generated Key5 | Undefined   |
| CRYPTO_PRNG_KEY6 | CRYPTO_BA+0x028 | R   | PRNG Generated Key6 | Undefined   |
| CRYPTO_PRNG_KEY7 | CRYPTO_BA+0x02C | R   | PRNG Generated Key7 | Undefined   |



| Bits   | Description |                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------|
| [31:0] | KEY         | Store PRNG Generated Key (Read Only)<br>The bits store the key that is generated by PRNG. |

## 6.36.7.3 AES Register

**AES Control Register (CRYPTO\_AES\_CTL)**

| Register       | Offset          | R/W | Description          |  |  |  | Reset Value |
|----------------|-----------------|-----|----------------------|--|--|--|-------------|
| CRYPTO_AES_CTL | CRYPTO_BA+0x100 | R/W | AES Control Register |  |  |  | 0x0000_0000 |

|        |          |          |          |       |    |      |         |
|--------|----------|----------|----------|-------|----|------|---------|
| 31     | 30       | 29       | 28       | 27    | 26 | 25   | 24      |
| KEYPRT | KEYUNPRT |          |          |       |    |      | CHANNEL |
| 23     | 22       | 21       | 20       | 19    | 18 | 17   | 16      |
| INSWAP | OUTSWAP  | Reserved |          |       |    |      |         |
| 15     | 14       | 13       | 12       | 11    | 10 | 9    | 8       |
| OPMODE |          |          |          |       |    |      |         |
| 7      | 6        | 5        | 4        | 3     | 2  | 1    | 0       |
| DMAEN  | DMACSCAD | DMALAST  | Reserved | KEYSZ |    | STOP | START   |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                   |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>KEYPRT</b><br><b>Protect Key</b><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 reading CRYPTO_AESn_KEYx is not the content of the registers CRYPTO_AESn_KEYx. Once it is set, it can be cleared by asserting KEYUNPRT. And the key content would be cleared as well. |
| [30:26] | <b>KEYUNPRT</b><br><b>Unprotect Key</b><br>Writing 0 to CRYPTO_AES_CTL[31] and "10110" to 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 engine is operating, BUSY flag is 1, there would be no effect on KEYUNPRT.                                                                |
| [25:24] | <b>CHANNEL</b><br><b>AES Engine Working Channel</b><br>00 = Current control register setting is for channel 0.<br>01 = Current control register setting is for channel 1.<br>10 = Current control register setting is for channel 2.<br>11 = Current control register setting is for channel 3.                                                               |
| [23]    | <b>INSWAP</b><br><b>AES Engine Input Data Swap</b><br>0 = Keep the original order.<br>1 = The order that CPU feeds data to the accelerator will be changed from {byte3, byte2, byte1, byte0} to {byte0, byte1, byte2, byte3}.                                                                                                                                 |
| [22]    | <b>OUTSWAP</b><br><b>AES Engine Output Data Swap</b><br>0 = Keep the original order.<br>1 = The order that CPU outputs data from the accelerator will be changed from {byte3, byte2, byte1, byte0} to {byte0, byte1, byte2, byte3}.                                                                                                                           |
| [17]    | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                                                                                                                  |

|        |                 |                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]   | <b>ENCRYPTO</b> | <b>AES Encryption/Decryption</b><br>0 = AES engine executes decryption operation.<br>1 = AES engine executes encryption operation.                                                                                                                                                                                                                                                                    |
| [15:8] | <b>OPMODE</b>   | <b>AES Engine Operation Modes</b><br>0x00 = ECB (Electronic Codebook Mode)<br>0x01 = CBC (Cipher Block Chaining Mode).<br>0x02 = CFB (Cipher Feedback Mode).<br>0x03 = OFB (Output Feedback Mode).<br>0x04 = CTR (Counter Mode).<br>0x10 = CBC-CS1 (CBC Ciphertext-Stealing 1 Mode).<br>0x11 = CBC-CS2 (CBC Ciphertext-Stealing 2 Mode).<br>0x12 = CBC-CS3 (CBC Ciphertext-Stealing 3 Mode).          |
| [7]    | <b>DMAEN</b>    | <b>AES Engine DMA Enable Bit</b><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]    | <b>DMACSCAD</b> | <b>AES Engine DMA with Cascade Mode</b><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]    | <b>DMALAST</b>  | <b>AES Last Block</b><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. |
| [3:2]  | <b>KEYSZ</b>    | <b>AES Key Size</b><br>This bit defines three different key size for AES operation.<br>2'b00 = 128 bits key.<br>2'b01 = 192 bits key.<br>2'b10 = 256 bits key.<br>2'b11 = Reserved.<br>If the AES accelerator is operating and the corresponding flag BUSY is 1, updating this register has no effect.                                                                                                |
| [1]    | <b>STOP</b>     | <b>AES Engine Stop</b><br>0 = No effect.<br>1 = Stop AES engine.<br><b>Note:</b> This bit is always 0 when it's read back.                                                                                                                                                                                                                                                                            |
| [0]    | <b>START</b>    | <b>AES Engine Start</b><br>0 = No effect.<br>1 = Start AES engine. BUSY flag will be set.<br><b>Note:</b> This bit is always 0 when it's read back.                                                                                                                                                                                                                                                   |

**AES Status Flag Register (CRYPTO\_AES\_STS)**

| Register       | Offset          | R/W | Description     |  |  | Reset Value |
|----------------|-----------------|-----|-----------------|--|--|-------------|
| CRYPTO_AES_STS | CRYPTO_BA+0x104 | R   | AES Engine Flag |  |  | 0x0001_0100 |

|          |    |    |        |          |           |            |             |
|----------|----|----|--------|----------|-----------|------------|-------------|
| 31       | 30 | 29 | 28     | 27       | 26        | 25         | 24          |
| Reserved |    |    |        |          |           |            |             |
| 23       | 22 | 21 | 20     | 19       | 18        | 17         | 16          |
| Reserved |    |    | BUSERR | Reserved | OUTBUFERR | OUTBUFFULL | OUTBUFEMPTY |
| 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 |                                                                                                                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |
| [20]    | BUSERR      | <b>AES DMA Access Bus Error Flag</b><br>0 = No error.<br>1 = Bus error will stop DMA operation and AES engine.                                                                                                                                                                           |
| [19]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |
| [18]    | OUTBUFERR   | <b>AES Out Buffer Error Flag</b><br>0 = No error.<br>1 = Error happens during getting the result from AES engine.                                                                                                                                                                        |
| [17]    | OUTBUFFULL  | <b>AES Out Buffer Full Flag</b><br>0 = AES output buffer is not full.<br>1 = AES output buffer is full, and software needs to get data from CRYPTO_AES_DATOUT. Otherwise, the AES engine will be pending since the output buffer is full.                                                |
| [16]    | OUTBUFEMPTY | <b>AES Out Buffer Empty</b><br>0 = AES output buffer is not empty. There are some valid data kept in output buffer.<br>1 = AES output buffer is empty. Software cannot get data from CRYPTO_AES_DATOUT. Otherwise, the flag OUTBUFERR will be set to 1 since the output buffer is empty. |
| [15:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |
| [12]    | CNTERR      | <b>CRYPTO_AESn_CNT Setting Error</b><br>0 = No error in CRYPTO_AESn_CNT setting.<br>1 = CRYPTO_AESn_CNT is 0 or not a multiply of 16 in ECB, CBC, CFB, OFB, and CTR mode if DMAEN (CRYPTO_AES_CTL[7]) is enabled.                                                                        |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |

|       |                   |                                                                                                                                                                                                                                                                    |
|-------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10]  | <b>INBUFERR</b>   | <b>AES Input Buffer Error Flag</b><br>0 = No error.<br>1 = Error happens during feeding data to the AES engine.                                                                                                                                                    |
| [9]   | <b>INBUFFULL</b>  | <b>AES Input Buffer Full Flag</b><br>0 = AES input buffer is not full. Software can feed the data into the AES engine.<br>1 = AES input buffer is full. Software cannot feed data to the AES engine. Otherwise, the flag INBUFERR will be set to 1.                |
| [8]   | <b>INBUFEMPTY</b> | <b>AES Input Buffer Empty</b><br>0 = There are some data in input buffer waiting for the AES engine to process.<br>1 = AES input buffer is empty. Software needs to feed data to the AES engine. Otherwise, the AES engine will be pending to wait for input data. |
| [7:1] | <b>Reserved</b>   | Reserved.                                                                                                                                                                                                                                                          |
| [0]   | <b>BUSY</b>       | <b>AES Engine Busy</b><br>0 = The AES engine is idle or finished.<br>1 = The AES engine is under processing.                                                                                                                                                       |

**AES Data Input Port Register (CRYPTO\_AES\_DATIN)**

| Register         | Offset          | R/W | Description                         | Reset Value |
|------------------|-----------------|-----|-------------------------------------|-------------|
| CRYPTO_AES_DATIN | CRYPTO_BA+0x108 | R/W | AES Engine Data Input Port Register | 0x0000_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       | <b>AES Engine Input Port</b><br>CPU feeds data to AES engine through this port by checking CRYPTO_AES_STS. Feed data as INBUFFULL is 0. |

AES Data Output Port Register (CRYPTO\_AES\_DATOUT)

| Register          | Offset          | R/W | Description                          |  |  | Reset Value |
|-------------------|-----------------|-----|--------------------------------------|--|--|-------------|
| CRYPTO_AES_DATOUT | CRYPTO_BA+0x10C | R   | AES Engine Data Output Port Register |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | DATOUT      | <b>AES Engine Output Port</b><br>CPU gets results from the AES engine through this port by checking CRYPTO_AES_STS. Get data as OUTBUFEMPTY is 0. |

**AES Key Word x Register (CRYPTO AES0 KEYx, CRYPTO AES1 KEYx, CRYPTO AES2 KEYx, CRYPTO AES3 KEYx)**

| Register         | Offset          | R/W | Description                           | Reset Value |
|------------------|-----------------|-----|---------------------------------------|-------------|
| CRYPTO_AES0_KEY0 | CRYPTO_BA+0x110 | R/W | AES Key Word 0 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_KEY1 | CRYPTO_BA+0x114 | R/W | AES Key Word 1 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_KEY2 | CRYPTO_BA+0x118 | R/W | AES Key Word 2 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_KEY3 | CRYPTO_BA+0x11C | R/W | AES Key Word 3 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_KEY4 | CRYPTO_BA+0x120 | R/W | AES Key Word 4 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_KEY5 | CRYPTO_BA+0x124 | R/W | AES Key Word 5 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_KEY6 | CRYPTO_BA+0x128 | R/W | AES Key Word 6 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_KEY7 | CRYPTO_BA+0x12C | R/W | AES Key Word 7 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES1_KEY0 | CRYPTO_BA+0x14C | R/W | AES Key Word 0 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_KEY1 | CRYPTO_BA+0x150 | R/W | AES Key Word 1 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_KEY2 | CRYPTO_BA+0x154 | R/W | AES Key Word 2 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_KEY3 | CRYPTO_BA+0x158 | R/W | AES Key Word 3 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_KEY4 | CRYPTO_BA+0x15C | R/W | AES Key Word 4 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_KEY5 | CRYPTO_BA+0x160 | R/W | AES Key Word 5 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_KEY6 | CRYPTO_BA+0x164 | R/W | AES Key Word 6 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_KEY7 | CRYPTO_BA+0x168 | R/W | AES Key Word 7 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES2_KEY0 | CRYPTO_BA+0x188 | R/W | AES Key Word 0 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_KEY1 | CRYPTO_BA+0x18C | R/W | AES Key Word 1 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_KEY2 | CRYPTO_BA+0x190 | R/W | AES Key Word 2 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_KEY3 | CRYPTO_BA+0x194 | R/W | AES Key Word 3 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_KEY4 | CRYPTO_BA+0x198 | R/W | AES Key Word 4 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_KEY5 | CRYPTO_BA+0x19C | R/W | AES Key Word 5 Register for Channel 2 | 0x0000_0000 |

|                         |                 |     |                                       |             |
|-------------------------|-----------------|-----|---------------------------------------|-------------|
| <b>CRYPTO_AES2_KEY6</b> | CRYPTO_BA+0x1A0 | R/W | AES Key Word 6 Register for Channel 2 | 0x0000_0000 |
| <b>CRYPTO_AES2_KEY7</b> | CRYPTO_BA+0x1A4 | R/W | AES Key Word 7 Register for Channel 2 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY0</b> | CRYPTO_BA+0x1C4 | R/W | AES Key Word 0 Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY1</b> | CRYPTO_BA+0x1C8 | R/W | AES Key Word 1 Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY2</b> | CRYPTO_BA+0x1CC | R/W | AES Key Word 2 Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY3</b> | CRYPTO_BA+0x1D0 | R/W | AES Key Word 3 Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY4</b> | CRYPTO_BA+0x1D4 | R/W | AES Key Word 4 Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY5</b> | CRYPTO_BA+0x1D8 | R/W | AES Key Word 5 Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY6</b> | CRYPTO_BA+0x1DC | R/W | AES Key Word 6 Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_AES3_KEY7</b> | CRYPTO_BA+0x1E0 | R/W | AES Key Word 7 Register for Channel 3 | 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 |    |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>KEY</b>  | <p><b>CRYPTO_AESn_KEYx</b><br/> The KEY keeps the security key for AES operation.<br/> n = 0, 1..3.<br/> x = 0, 1..7.</p> <p>The security key for AES accelerator can be 128, 192, or 256 bits and four, six, or eight 32-bit registers are to store each security key. {CRYPTO_AESn_KEY3, CRYPTO_AESn_KEY2, CRYPTO_AESn_KEY1, CRYPTO_AESn_KEY0} stores the 128-bit security key for AES operation. {CRYPTO_AESn_KEY5, CRYPTO_AESn_KEY4, CRYPTO_AESn_KEY3, CRYPTO_AESn_KEY2, CRYPTO_AESn_KEY1, CRYPTO_AESn_KEY0} stores the 192-bit security key for AES operation. {CRYPTO_AESn_KEY7, CRYPTO_AESn_KEY6, CRYPTO_AESn_KEY5, CRYPTO_AESn_KEY4, CRYPTO_AESn_KEY3, CRYPTO_AESn_KEY2, CRYPTO_AESn_KEY1, CRYPTO_AESn_KEY0} stores the 256-bit security key for AES operation.</p> |

AES Initial Vector Word x Register (CRYPTO\_AES0\_IVx, CRYPTO\_AES1\_IVx,  
CRYPTO AES2 IVx, CRYPTO AES3 IVx)

| Register         | Offset          | R/W | Description                                      | Reset Value |
|------------------|-----------------|-----|--------------------------------------------------|-------------|
| CRYPTO_AES0_I_V0 | CRYPTO_BA+0x130 | R/W | AES Initial Vector Word 0 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_I_V1 | CRYPTO_BA+0x134 | R/W | AES Initial Vector Word 1 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_I_V2 | CRYPTO_BA+0x138 | R/W | AES Initial Vector Word 2 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES0_I_V3 | CRYPTO_BA+0x13C | R/W | AES Initial Vector Word 3 Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES1_I_V0 | CRYPTO_BA+0x16C | R/W | AES Initial Vector Word 0 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_I_V1 | CRYPTO_BA+0x170 | R/W | AES Initial Vector Word 1 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_I_V2 | CRYPTO_BA+0x174 | R/W | AES Initial Vector Word 2 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES1_I_V3 | CRYPTO_BA+0x178 | R/W | AES Initial Vector Word 3 Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES2_I_V0 | CRYPTO_BA+0x1A8 | R/W | AES Initial Vector Word 0 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_I_V1 | CRYPTO_BA+0x1AC | R/W | AES Initial Vector Word 1 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_I_V2 | CRYPTO_BA+0x1B0 | R/W | AES Initial Vector Word 2 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES2_I_V3 | CRYPTO_BA+0x1B4 | R/W | AES Initial Vector Word 3 Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES3_I_V0 | CRYPTO_BA+0x1E4 | R/W | AES Initial Vector Word 0 Register for Channel 3 | 0x0000_0000 |
| CRYPTO_AES3_I_V1 | CRYPTO_BA+0x1E8 | R/W | AES Initial Vector Word 1 Register for Channel 3 | 0x0000_0000 |
| CRYPTO_AES3_I_V2 | CRYPTO_BA+0x1EC | R/W | AES Initial Vector Word 2 Register for Channel 3 | 0x0000_0000 |
| CRYPTO_AES3_I_V3 | CRYPTO_BA+0x1F0 | R/W | AES Initial Vector Word 3 Register for Channel 3 | 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                                                                                                                                                                                                                                                                                                                                                                          |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>IV</b><br><b>AES Initial Vectors</b><br>n = 0, 1..3.<br>x = 0, 1..3.<br>Four initial vectors (CRYPTO_AESn_IV0, CRYPTO_AESn_IV1, CRYPTO_AESn_IV2, and CRYPTO_AESn_IV3) are for AES operating in CBC, CFB, and OFB mode. Four registers (CRYPTO_AESn_IV0, CRYPTO_AESn_IV1, CRYPTO_AESn_IV2, and CRYPTO_AESn_IV3) act as Nonce counter when the AES engine is operating in CTR mode. |

**AES DMA Source Address Register (CRYPTO\_AES0\_SADDR, CRYPTO\_AES1\_SADDR,  
CRYPTO AES2 SADDR, CRYPTO AES3 SADDR)**

| Register           | Offset          | R/W | Description                                   | Reset Value |
|--------------------|-----------------|-----|-----------------------------------------------|-------------|
| CRYPTO_AES0_SADD R | CRYPTO_BA+0x140 | R/W | AES DMA Source Address Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES1_SADD R | CRYPTO_BA+0x17C | R/W | AES DMA Source Address Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES2_SADD R | CRYPTO_BA+0x1B8 | R/W | AES DMA Source Address Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES3_SADD R | CRYPTO_BA+0x1F4 | R/W | AES DMA Source Address Register for Channel 3 | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SADDR       | <p><b>AES DMA Source Address</b></p> <p>The AES accelerator supports DMA function to transfer the plain text between SRAM memory space and embedded FIFO. The SADDR keeps the source address of the data buffer where the source text is stored. Based on the source address, the AES accelerator can read the plain text (encryption) / cipher text (decryption) from SRAM memory space and do AES operation. The start of source address should be located at word boundary. In other words, bit 1 and 0 of SADDR are ignored.</p> <p>SADDR can be read and written. Writing to SADDR while the AES accelerator is operating doesn't affect the current AES operation. But the value of SADDR will be updated later on. Consequently, software can prepare the DMA source address for the next AES operation.</p> <p>In DMA mode, software can update the next CRYPTO_AESn_SADDR before triggering START.</p> <p>The value of CRYPTO_AESn_SADDR and CRYPTO_AESn_DADDR can be the same.</p> |

**AES DMA Destination Address Register (CRYPTO\_AES0\_DADDR, CRYPTO\_AES1\_DADDR, CRYPTO\_AES2\_DADDR, CRYPTO\_AES3\_DADDR)**

| Register           | Offset           | R/W | Description                                        | Reset Value |
|--------------------|------------------|-----|----------------------------------------------------|-------------|
| CRYPTO_AES0_DAD DR | CRYPTO_BA+0x144  | R/W | AES DMA Destination Address Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES1_DAD DR | CRYPTO_BA+0x180  | R/W | AES DMA Destination Address Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES2_DAD DR | CRYPTO_BA+0x1B C | R/W | AES DMA Destination Address Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES3_DAD DR | CRYPTO_BA+0x1F 8 | R/W | AES DMA Destination Address Register for Channel 3 | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | DADDR       | <p><b>AES DMA Destination Address</b></p> <p>The AES accelerator supports DMA function to transfer the cipher text between SRAM memory space and embedded FIFO. The DADDR keeps the destination address of the data buffer where the engine output's text will be stored. Based on the destination address, the AES accelerator can write the cipher text (encryption) / plain text (decryption) back to SRAM memory space after the AES operation is finished. The start of destination address should be located at word boundary. In other words, bit 1 and 0 of DADDR are ignored.</p> <p>DADDR can be read and written. Writing to DADDR while the AES accelerator is operating doesn't affect the current AES operation. But the value of DADDR will be updated later on. Consequently, software can prepare the destination address for the next AES operation.</p> <p>In DMA mode, software can update the next CRYPTO_AESn_SADDR and CRYPTO_AESn_DADDR before triggering START.</p> <p>The value of CRYPTO_AESn_SADDR and CRYPTO_AESn_DADDR can be the same.</p> |

**AES Byte Count Register (CRYPTO\_AES0\_CNT, CRYPTO\_AES1\_CNT, CRYPTO\_AES2\_CNT, CRYPTO\_AES3\_CNT)**

| Register        | Offset          | R/W | Description                           | Reset Value |
|-----------------|-----------------|-----|---------------------------------------|-------------|
| CRYPTO_AES0_CNT | CRYPTO_BA+0x148 | R/W | AES Byte Count Register for Channel 0 | 0x0000_0000 |
| CRYPTO_AES1_CNT | CRYPTO_BA+0x184 | R/W | AES Byte Count Register for Channel 1 | 0x0000_0000 |
| CRYPTO_AES2_CNT | CRYPTO_BA+0x1C0 | R/W | AES Byte Count Register for Channel 2 | 0x0000_0000 |
| CRYPTO_AES3_CNT | CRYPTO_BA+0x1FC | R/W | AES Byte Count Register for Channel 3 | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | CNT         | <p><b>AES Byte Count</b></p> <p>The CRYPTO_AESn_CNT keeps the byte count of source text that is for the AES engine operating in DMA mode. The CRYPTO_AESn_CNT is 32-bit and the maximum of byte count is 4G bytes.</p> <p>CRYPTO_AESn_CNT can be read and written. Writing to CRYPTO_AESn_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.</p> <p>According to CBC-CS1, CBC-CS2, and CBC-CS3 standard, the count of operation data must be more than 16 bytes. Operations that are qual or less than one block will output unexpected result.</p> <p>In Non-DMA ECB, CBC, CFB, OFB, and CTR mode, CRYPTO_AESn_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_AESn_CNT must be set as byte count for the last two blocks of data before feeding in the last two blocks of data.</p> |

**AES Feedback x Register (CRYPTO\_AES\_FDBCKx)**

| Register          | Offset          | R/W | Description                                                   | Reset Value |
|-------------------|-----------------|-----|---------------------------------------------------------------|-------------|
| 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 |



| Bits   | Description  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>FDBCK</b> | <p><b>AES Feedback Information</b></p> <p>The feedback value is 128 bits in size.</p> <p>The AES engine uses the data from CRYPTO_AES_FDBCKx as the data inputted to CRYPTO_AESn_IVx for the next block in DMA cascade mode.</p> <p>The AES engine outputs feedback information for IV in the next block's operation. Software can use this feedback information to implement more than four DMA channels. Software can store that feedback value temporarily. After switching back, fill the stored feedback value to CRYPTO_AESn_IVx in the same channel operation, and then continue the operation with the original setting.</p> |

## 6.36.7.4 TDES/DES Register

**TDES/DES Control Register (CRYPTO\_TDES\_CTL)**

| Register        | Offset          | R/W | Description               |  |  |  | Reset Value |
|-----------------|-----------------|-----|---------------------------|--|--|--|-------------|
| CRYPTO_TDES_CTL | CRYPTO_BA+0x200 | R/W | TDES/DES Control Register |  |  |  | 0x0000_0000 |

|          |          |         |          |        |         |          |       |
|----------|----------|---------|----------|--------|---------|----------|-------|
| 31       | 30       | 29      | 28       | 27     | 26      | 25       | 24    |
| KEYPRT   | KEYUNPRT |         |          |        | CHANNEL |          |       |
| 23       | 22       | 21      | 20       | 19     | 18      | 17       | 16    |
| INSWAP   | OUTSWAP  | BLKSWAP | Reserved |        |         | ENCRYPTO |       |
| 15       | 14       | 13      | 12       | 11     | 10      | 9        | 8     |
| Reserved |          |         |          | OPMODE |         |          |       |
| 7        | 6        | 5       | 4        | 3      | 2       | 1        | 0     |
| DMAEN    | DMACSCAD | DMALAST | Reserved | 3KEYS  | TMODE   | STOP     | START |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | <b>KEYPRT</b><br><b>Protect Key</b><br>Read as a flag to reflect KEYPRT.<br>0 = No effect.<br>1 = This bit is to protect the content of TDES key from reading. The return value for reading CRYPTO_TDESn_KEYxH/L is not the content in the registers CRYPTO_TDESn_KEYxH/L. Once it is set, it can be cleared by asserting KEYUNPRT. The key content would be cleared as well. |
| [30:26] | <b>KEYUNPRT</b><br><b>Unprotect Key</b><br>Writing 0 to CRYPTO_TDES_CTL [31] and "10110" to CRYPTO_TDES_CTL [30:26] is to unprotect TDES key.<br>The KEYUNPRT can be read and written. When it is written as the TDES engine is operating, BUSY flag is 1, there would be no effect on KEYUNPRT.                                                                              |
| [25:24] | <b>CHANNEL</b><br><b>TDES/DES Engine Working Channel</b><br>00 = Current control register setting is for channel 0.<br>01 = Current control register setting is for channel 1.<br>10 = Current control register setting is for channel 2.<br>11 = Current control register setting is for channel 3.                                                                          |
| [23]    | <b>INSWAP</b><br><b>TDES/DES Engine Input Data Swap</b><br>0 = Keep the original order.<br>1 = The order that CPU feeds data to the accelerator will be changed from {byte3, byte2, byte1, byte0} to {byte0, byte1, byte2, byte3}.                                                                                                                                            |
| [22]    | <b>OUTSWAP</b><br><b>TDES/DES Engine Output Data Swap</b><br>0 = Keep the original order.<br>1 = The order that CPU outputs data from the accelerator will be changed from {byte3, byte2, byte1, byte0} to {byte0, byte1, byte2, byte3}.                                                                                                                                      |

|         |                 |                                                                                                                                                                                                                                                                                                   |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [21]    | <b>BLKSWAP</b>  | <b>TDES/DES Engine Block Double Word Endian Swap</b><br>0 = Keep the original order, e.g. {WORD_H, WORD_L}.<br>1 = When this bit is set to 1, the TDES engine would exchange high and low word in the sequence {WORD_L, WORD_H}.                                                                  |
| [20:17] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                         |
| [16]    | <b>ENCRYPTO</b> | <b>TDES/DES Encryption/Decryption</b><br>0 = TDES engine executes decryption operation.<br>1 = TDES engine executes encryption operation.                                                                                                                                                         |
| [15:11] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                         |
| [10:8]  | <b>OPMODE</b>   | <b>TDES/DES Engine Operation Mode</b><br>0x00 = ECB (Electronic Codebook Mode).<br>0x01 = CBC (Cipher Block Chaining Mode).<br>0x02 = CFB (Cipher Feedback Mode).<br>0x03 = OFB (Output Feedback Mode).<br>0x04 = CTR (Counter Mode).<br>Others = CTR (Counter Mode).                             |
| [7]     | <b>DMAEN</b>    | <b>TDES/DES Engine DMA Enable Bit</b><br>0 = TDES_DMA engine Disabled.<br>TDES engine operates in Non-DMA mode. The data need to be written in CRYPTO_TDES_DATIN.<br>1 = TDES_DMA engine Enabled.<br>TDES engine operates in DMA mode, and data movement from/to the engine is done by DMA logic. |
| [6]     | <b>DMACSCAD</b> | <b>TDES/DES Engine DMA with Cascade Mode</b><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]     | <b>DMALAST</b>  | <b>TDES/DES Engine Start for the Last Block</b><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 as feeding in last block of data.                                                                                          |
| [4]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                         |
| [3]     | <b>3KEYS</b>    | <b>TDES/DES Key Number</b><br>0 = Select KEY1 and KEY2 in TDES/DES engine.<br>1 = Triple keys in TDES/DES engine Enabled.                                                                                                                                                                         |
| [2]     | <b>TMODE</b>    | <b>TDES/DES Engine Operating Mode</b><br>0 = Set DES mode for TDES/DES engine.<br>1 = Set Triple DES mode for TDES/DES engine.                                                                                                                                                                    |
| [1]     | <b>STOP</b>     | <b>TDES/DES Engine Stop</b><br>0 = No effect.<br>1 = Stop TDES/DES engine.<br><b>Note:</b> The bit is always 0 when it's read back.                                                                                                                                                               |

|     |       |                                                                                                                                                                   |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | START | <b>TDES/DES Engine Start</b><br>0 = No effect.<br>1 = Start TDES/DES engine. The flag BUSY would be set.<br><b>Note:</b> The bit is always 0 when it's read back. |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**TDES/DES Status Flag Register (CRYPTO\_TDES0\_STS)**

| Register        | Offset          | R/W | Description          |  |  | Reset Value |
|-----------------|-----------------|-----|----------------------|--|--|-------------|
| CRYPTO_TDES_STS | CRYPTO_BA+0x204 | R   | TDES/DES Engine Flag |  |  | 0x0001_0100 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |
| [20]    | BUSERR      | <b>TDES/DES DMA Access Bus Error Flag</b><br>0 = No error.<br>1 = Bus error will stop DMA operation and TDES/DES engine.                                                                                                                                                                                |
| [19]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |
| [18]    | OUTBUFERR   | <b>TDES/DES Out Buffer Error Flag</b><br>0 = No error.<br>1 = Error happens during getting test result from TDES/DES engine.                                                                                                                                                                            |
| [17]    | OUTBUFFULL  | <b>TDES/DES Output Buffer Full Flag</b><br>0 = TDES/DES output buffer is not full.<br>1 = TDES/DES output buffer is full, and software needs to get data from TDES_DATA_OUT. Otherwise, the TDES/DES engine will be pending since output buffer is full.                                                |
| [16]    | OUTBUFEMPTY | <b>TDES/DES Output Buffer Empty Flag</b><br>0 = TDES/DES output buffer is not empty. There are some valid data kept in output buffer.<br>1 = TDES/DES output buffer is empty, Software cannot get data from TDES_DATA_OUT. Otherwise the flag OUTBUFERR will be set to 1, since output buffer is empty. |
| [15:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |
| [10]    | INBUFERR    | <b>TDES/DES in Buffer Error Flag</b><br>0 = No error.<br>1 = Error happens during feeding data to the TDES/DES engine.                                                                                                                                                                                  |

|       |                   |                                                                                                                                                                                                                                                                                          |
|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9]   | <b>INBUFFULL</b>  | <b>TDES/DES in Buffer Full Flag</b><br>0 = TDES/DES input buffer is not full. Software can feed the data into the TDES/DES engine.<br>1 = TDES input buffer is full. Software cannot feed data to the TDES/DES engine. Otherwise, the flag INBUFERR will be set to 1.                    |
| [8]   | <b>INBUFEMPTY</b> | <b>TDES/DES in Buffer Empty</b><br>0 = There are some data in input buffer waiting for the TDES/DES engine to process.<br>1 = TDES/DES input buffer is empty. Software needs to feed data to the TDES/DES engine. Otherwise, the TDES/DES engine will be pending to wait for input data. |
| [7:1] | <b>Reserved</b>   | Reserved.                                                                                                                                                                                                                                                                                |
| [0]   | <b>BUSY</b>       | <b>TDES/DES Engine Busy</b><br>0 = TDES/DES engine is idle or finished.<br>1 = TDES/DES engine is under processing.                                                                                                                                                                      |

**TDES/DES Key 1, 2, 3 High/Low Word Register (TDES\_KEY1H/L, TDES\_KEY2H/L, TDES\_KEY3H/L)**

| Register            | Offset          | R/W | Description                                     | Reset Value |
|---------------------|-----------------|-----|-------------------------------------------------|-------------|
| CRYPTO_TDES0_KEY1_H | CRYPTO_BA+0x208 | R/W | TDES/DES Key 1 High Word Register for Channel 0 | 0x0000_0000 |
| CRYPTO_TDES0_KEY1_L | CRYPTO_BA+0x20C | R/W | TDES/DES Key 1 Low Word Register for Channel 0  | 0x0000_0000 |
| CRYPTO_TDES0_KEY2_H | CRYPTO_BA+0x210 | R/W | TDES Key 2 High Word Register for Channel 0     | 0x0000_0000 |
| CRYPTO_TDES0_KEY2_L | CRYPTO_BA+0x214 | R/W | TDES Key 2 Low Word Register for Channel 0      | 0x0000_0000 |
| CRYPTO_TDES0_KEY3_H | CRYPTO_BA+0x218 | R/W | TDES Key 3 High Word Register for Channel 0     | 0x0000_0000 |
| CRYPTO_TDES0_KEY3_L | CRYPTO_BA+0x21C | R/W | TDES Key 3 Low Word Register for Channel 0      | 0x0000_0000 |
| CRYPTO_TDES1_KEY1_H | CRYPTO_BA+0x248 | R/W | TDES/DES Key 1 High Word Register for Channel 1 | 0x0000_0000 |
| CRYPTO_TDES1_KEY1_L | CRYPTO_BA+0x24C | R/W | TDES/DES Key 1 Low Word Register for Channel 1  | 0x0000_0000 |
| CRYPTO_TDES1_KEY2_H | CRYPTO_BA+0x250 | R/W | TDES Key 2 High Word Register for Channel 1     | 0x0000_0000 |
| CRYPTO_TDES1_KEY2_L | CRYPTO_BA+0x254 | R/W | TDES Key 2 Low Word Register for Channel 1      | 0x0000_0000 |
| CRYPTO_TDES1_KEY3_H | CRYPTO_BA+0x258 | R/W | TDES Key 3 High Word Register for Channel 1     | 0x0000_0000 |
| CRYPTO_TDES1_KEY3_L | CRYPTO_BA+0x25C | R/W | TDES Key 3 Low Word Register for Channel 1      | 0x0000_0000 |
| CRYPTO_TDES2_KEY1_H | CRYPTO_BA+0x288 | R/W | TDES/DES Key 1 High Word Register for Channel 2 | 0x0000_0000 |
| CRYPTO_TDES2_KEY1_L | CRYPTO_BA+0x28C | R/W | TDES/DES Key 1 Low Word Register for Channel 2  | 0x0000_0000 |
| CRYPTO_TDES2_KEY2_H | CRYPTO_BA+0x290 | R/W | TDES Key 2 High Word Register for Channel 2     | 0x0000_0000 |
| CRYPTO_TDES2_KEY2_L | CRYPTO_BA+0x294 | R/W | TDES Key 2 Low Word Register for Channel 2      | 0x0000_0000 |
| CRYPTO_TDES2_KEY3_H | CRYPTO_BA+0x298 | R/W | TDES Key 3 High Word Register for Channel 2     | 0x0000_0000 |
| CRYPTO_TDES2_KEY3_L | CRYPTO_BA+0x29C | R/W | TDES Key 3 Low Word Register for Channel 2      | 0x0000_0000 |
| CRYPTO_TDES3_KEY1_H | CRYPTO_BA+0x2C8 | R/W | TDES/DES Key 1 High Word Register for Channel 3 | 0x0000_0000 |
| CRYPTO_TDES3_KEY1_L | CRYPTO_BA+0x2CC | R/W | TDES/DES Key 1 Low Word Register for Channel 3  | 0x0000_0000 |
| CRYPTO_TDES3_KEY2_H | CRYPTO_BA+0x2D0 | R/W | TDES Key 2 High Word Register for Channel 3     | 0x0000_0000 |
| CRYPTO_TDES3_KEY2_L | CRYPTO_BA+0x2D4 | R/W | TDES Key 2 Low Word Register for Channel 3      | 0x0000_0000 |

|                            |                 |     |                                             |             |
|----------------------------|-----------------|-----|---------------------------------------------|-------------|
| <b>CRYPTO_TDES3_KEY3_H</b> | CRYPTO_BA+0x2D8 | R/W | TDES Key 3 High Word Register for Channel 3 | 0x0000_0000 |
| <b>CRYPTO_TDES3_KEY3_L</b> | CRYPTO_BA+0x2DC | R/W | TDES Key 3 Low Word Register for Channel 3  | 0x0000_0000 |



| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <p><b>TDES/DES Key High/Low Word</b></p> <p>The key registers for TDES/DES algorithm calculation</p> <p>The security key for the TDES/DES accelerator is 64 bits. Thus, it needs two 32-bit registers to store a security key. The register CRYPTO_TDESn_KEYxH is used to keep the bit [63:32] of security key for the TDES/DES operation, while the register CRYPTO_TDESn_KEYxL is used to keep the bit [31:0].</p> |

**TDES/DES IV High/Low Word Register (CRYPTO\_TDES0\_IVH/L, CRYPTO\_TDES1\_IVH/L,  
CRYPTO\_TDES2\_IVH/L, CRYPTO\_TDES3\_IVH/L)**

| Register         | Offset          | R/W | Description                                              | Reset Value |
|------------------|-----------------|-----|----------------------------------------------------------|-------------|
| CRYPTO_TDES0_IVH | CRYPTO_BA+0x220 | R/W | TDES/DES Initial Vector High Word Register for Channel 0 | 0x0000_0000 |
| CRYPTO_TDES0_IVL | CRYPTO_BA+0x224 | R/W | TDES/DES Initial Vector Low Word Register for Channel 0  | 0x0000_0000 |
| CRYPTO_TDES1_IVH | CRYPTO_BA+0x260 | R/W | TDES/DES Initial Vector High Word Register for Channel 1 | 0x0000_0000 |
| CRYPTO_TDES1_IVL | CRYPTO_BA+0x264 | R/W | TDES/DES Initial Vector Low Word Register for Channel 1  | 0x0000_0000 |
| CRYPTO_TDES2_IVH | CRYPTO_BA+0x2A0 | R/W | TDES/DES Initial Vector High Word Register for Channel 2 | 0x0000_0000 |
| CRYPTO_TDES2_IVL | CRYPTO_BA+0x2A4 | R/W | TDES/DES Initial Vector Low Word Register for Channel 2  | 0x0000_0000 |
| CRYPTO_TDES3_IVH | CRYPTO_BA+0x2E0 | R/W | TDES/DES Initial Vector High Word Register for Channel 3 | 0x0000_0000 |
| CRYPTO_TDES3_IVL | CRYPTO_BA+0x2E4 | R/W | TDES/DES Initial Vector Low Word Register for Channel 3  | 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 |                                                                                                                                                                            |  |  |  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| [31:0] | IV          | <b>TDES/DES Initial Vector High/Low Word</b><br>Initial vector (IV) is for TDES/DES engine in CBC, CFB, and OFB mode. IV is Nonce counter for TDES/DES engine in CTR mode. |  |  |  |  |  |  |  |

**TDES/DES DMA Source Address Register (CRYPTO\_TDES0\_SADDR, CRYPTO\_TDES1\_SADDR, CRYPTO\_TDES2\_SADDR, CRYPTO\_TDES3\_SADDR)**

| Register           | Offset          | R/W | Description                                        | Reset Value |
|--------------------|-----------------|-----|----------------------------------------------------|-------------|
| CRYPTO_TDES0_SADDR | CRYPTO_BA+0x28  | R/W | TDES/DES DMA Source Address Register for Channel 0 | 0x0000_0000 |
| CRYPTO_TDES1_SADDR | CRYPTO_BA+0x268 | R/W | TDES/DES DMA Source Address Register for Channel 1 | 0x0000_0000 |
| CRYPTO_TDES2_SADDR | CRYPTO_BA+0x2A8 | R/W | TDES/DES DMA Source Address Register for Channel 2 | 0x0000_0000 |
| CRYPTO_TDES3_SADDR | CRYPTO_BA+0x2E8 | R/W | TDES/DES DMA Source Address Register for Channel 3 | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | SADDR       | <p><b>TDES/DES DMA Source Address</b></p> <p>The TDES/DES accelerator supports DMA function to transfer the plain text between SRAM memory space and embedded FIFO. The CRYPTO_TDES<sub>n</sub>_SADDR keeps the source address of the data buffer where the source text is stored. Based on the source address, the TDES/DES accelerator can read the plain text (encryption) / cipher text (decryption) from SRAM memory space and do TDES/DES operation. The start of source address should be located at word boundary. In other words, bit 1 and 0 of CRYPTO_TDES<sub>n</sub>_SADDR are ignored.</p> <p>CRYPTO_TDES<sub>n</sub>_SADDR can be read and written. Writing to CRYPTO_TDES<sub>n</sub>_SADDR while the TDES/DES accelerator is operating doesn't affect the current TDES/DES operation. But the value of CRYPTO_TDES<sub>n</sub>_SADDR will be updated later on. Consequently, software can prepare the DMA source address for the next TDES/DES operation.</p> <p>In DMA mode, software can update the next CRYPTO_TDES<sub>n</sub>_SADDR before triggering START.</p> <p>CRYPTO_TDES<sub>n</sub>_SADDR and CRYPTO_TDES<sub>n</sub>_DADDR can be the same in the value.</p> |

**TDES/DES DMA Destination Address Register (CRYPTO\_TDES0\_DADDR, CRYPTO\_TDES1\_DADDR, CRYPTO\_TDES2\_DADDR, CRYPTO\_TDES3\_DADDR)**

| Register            | Offset           | R/W | Description                                             | Reset Value |
|---------------------|------------------|-----|---------------------------------------------------------|-------------|
| CRYPTO_TDES0_DAD DR | CRYPTO_BA+0x22 C | R/W | TDES/DES DMA Destination Address Register for Channel 0 | 0x0000_0000 |
| CRYPTO_TDES1_DAD DR | CRYPTO_BA+0x26 C | R/W | TDES/DES DMA Destination Address Register for Channel 1 | 0x0000_0000 |
| CRYPTO_TDES2_DAD DR | CRYPTO_BA+0x2A C | R/W | TDES/DES DMA Destination Address Register for Channel 2 | 0x0000_0000 |
| CRYPTO_TDES3_DAD DR | CRYPTO_BA+0x2E C | R/W | TDES/DES DMA Destination Address Register for Channel 3 | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | DADDR       | <p><b>TDES/DES DMA Destination Address</b></p> <p>The TDES/DES accelerator supports DMA function to transfer the cipher text between SRAM memory space and embedded FIFO. The CRYPTO_TDES<sub>n</sub>_DADDR keeps the destination address of the data buffer where the engine output's text will be stored. Based on the destination address, the TDES/DES accelerator can write the cipher text (encryption) / plain text (decryption) back to SRAM memory space after the TDES/DES operation is finished. The start of destination address should be located at word boundary. In other words, bit 1 and 0 of CRYPTO_TDES<sub>n</sub>_DADDR are ignored.</p> <p>CRYPTO_TDES<sub>n</sub>_DADDR can be read and written. Writing to CRYPTO_TDES<sub>n</sub>_DADDR while the TDES/DES accelerator is operating doesn't affect the current TDES/DES operation. But the value of CRYPTO_TDES<sub>n</sub>_DADDR will be updated later on. Consequently, software can prepare the destination address for the next TDES/DES operation.</p> <p>In DMA mode, software can update the next CRYPTO_TDES<sub>n</sub>_DADDR before triggering START.</p> <p>CRYPTO_TDES<sub>n</sub>_SADDR and CRYPTO_TDES<sub>n</sub>_DADDR can be the same in the value.</p> |

**TDES/DES Block Count Register (CRYPTO\_TDES0\_CNT, CRYPTO\_TDES1\_CNT,  
CRYPTO\_TDES2\_CNT, CRYPTO\_TDES3\_CNT)**

| Register         | Offset          | R/W | Description                                | Reset Value |
|------------------|-----------------|-----|--------------------------------------------|-------------|
| CRYPTO_TDES0_CNT | CRYPTO_BA+0x230 | R/W | TDES/DES Byte Count Register for Channel 0 | 0x0000_0000 |
| CRYPTO_TDES1_CNT | CRYPTO_BA+0x270 | R/W | TDES/DES Byte Count Register for Channel 1 | 0x0000_0000 |
| CRYPTO_TDES2_CNT | CRYPTO_BA+0x2B0 | R/W | TDES/DES Byte Count Register for Channel 2 | 0x0000_0000 |
| CRYPTO_TDES3_CNT | CRYPTO_BA+0x2F0 | R/W | TDES/DES Byte Count Register for Channel 3 | 0x0000_0000 |



| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>CNT</b>  | <p><b>TDES/DES Byte Count</b></p> <p>The CRYPTO_TDESn_CNT keeps the byte count of source text that is for the TDES/DES engine operating in DMA mode. The CRYPTO_TDESn_CNT is 32-bit and the maximum of byte count is 4G bytes.</p> <p>CRYPTO_TDESn_CNT can be read and written. Writing to CRYPTO_TDESn_CNT while the TDES/DES accelerator is operating doesn't affect the current TDES/DES operation. But the value of CRYPTO_TDESn_CNT will be updated later on. Consequently, software can prepare the byte count of data for the next TDES /DES operation.</p> <p>In Non-DMA ECB, CBC, CFB, OFB, and CTR mode, CRYPTO_TDESn_CNT must be set as byte count for the last block of data before feeding in the last block of data.</p> |

TDES/DES Data Input Port Register (CRYPTO\_TDES\_DATIN)

| Register          | Offset          | R/W | Description                              |  |  | Reset Value |
|-------------------|-----------------|-----|------------------------------------------|--|--|-------------|
| CRYPTO_TDES_DATIN | CRYPTO_BA+0x234 | R/W | TDES/DES Engine Input data Word Register |  |  | 0x0000_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       | <b>TDES/DES Engine Input Port</b><br>CPU feeds data to TDES/DES engine through this port by checking CRYPTO_TDES_STS.<br>Feed data as INBUFFULL is 0. |

**TDES/DES Data Output Port Register (CRYPTO\_TDES\_DATOUT)**

| Register           | Offset          | R/W | Description                               |  |  | Reset Value |
|--------------------|-----------------|-----|-------------------------------------------|--|--|-------------|
| CRYPTO_TDES_DATOUT | CRYPTO_BA+0x238 | R   | TDES/DES Engine Output data Word Register |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                        |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | DATOUT      | <p><b>TDES/DES Engine Output Port</b></p> <p>CPU gets result from the TDES/DES engine through this port by checking CRYPTO_TDES_STS. Get data as OUTBUFEMPTY is 0.</p> |

**TDES/DES Feedback x Register (CRYPTO\_TDES\_FDBCKx)**

| Register            | Offset          | R/W | Description                                                                               |  |  |  | Reset Value |
|---------------------|-----------------|-----|-------------------------------------------------------------------------------------------|--|--|--|-------------|
| CRYPTO_TDES_FDBCK_H | CRYPTO_BA+0x060 | R   | TD <sub>E</sub> S/DES Engine Output Feedback High Word Data after Cryptographic Operation |  |  |  | 0x0000_0000 |
| CRYPTO_TDES_FDBCK_L | CRYPTO_BA+0x064 | R   | TD <sub>E</sub> S/DES Engine Output Feedback Low Word Data after Cryptographic Operation  |  |  |  | 0x0000_0000 |

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

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <p><b>TDES/DES Feedback</b></p> <p>The feedback value is 64 bits in size.</p> <p>The TD<sub>E</sub>S/DES engine uses the data from {CRYPTO_TDES_FDBCKH, CRYPTO_TDES_FDBCKL} as the data inputted to {CRYPTO_TDESn_IVH, CRYPTO_TDESn_IVL} for the next block in DMA cascade mode. The feedback register is for CBC, CFB, and OFB mode.</p> <p>TD<sub>E</sub>S/DES engine outputs feedback information for IV in the next block's operation. Software can use this feedback information to implement more than four DMA channels. Software can store that feedback value temporarily. After switching back, fill the stored feedback value to CRYPTO_TDESn_IVH/L in the same channel operation. Then can continue the operation with the original setting.</p> |

## 6.36.7.5 SHA/HMAC Register

**SHA/HMAC Control Register (CRYPTO\_HMAC\_CTL)**

| Register        | Offset          | R/W | Description               |  |  |  | Reset Value |
|-----------------|-----------------|-----|---------------------------|--|--|--|-------------|
| CRYPTO_HMAC_CTL | CRYPTO_BA+0x300 | R/W | SHA/HMAC Control Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description                                                                                                                                                                                                                                                                                                                |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved                                                                                                                                                                                                                                                                                                                   |
| [23]    | <b>INSWAP</b><br>SHA/HMAC Engine Input Data Swap<br>0 = Keep the original order.<br>1 = The order that CPU feeds data to the accelerator will be changed from {byte3, byte2, byte1, byte0} to {byte0, byte1, byte2, byte3}.                                                                                                |
| [22]    | <b>OUTSWAP</b><br>SHA/HMAC Engine Output Data Swap<br>0 = Keep the original order.<br>1 = The order that CPU feeds data to the accelerator will be changed from {byte3, byte2, byte1, byte0} to {byte0, byte1, byte2, byte3}.                                                                                              |
| [21:11] | Reserved                                                                                                                                                                                                                                                                                                                   |
| [10:8]  | <b>OPMODE</b><br>SHA/HMAC Engine Operation Modes<br>0x0xx: SHA160<br>0x100: SHA256<br>0x101: SHA224<br>0x110: SHA512<br>0x111: SHA384<br><b>Note:</b> =These bits can be read and written. But writing to them wouldn't take effect as BUSY is 1.                                                                          |
| [7]     | <b>DMAEN</b><br>SHA/HMAC Engine DMA Enable Bit<br>0 = SHA/HMAC DMA engine Disabled.<br>SHA/HMAC engine operates in Non-DMA mode. The data need to be written in CRYPTO_HMAC_DATIN.<br>1 = SHA/HMAC DMA engine Enabled.<br>SHA/HMAC engine operates in DMA mode, and data movement from/to the engine is done by DMA logic. |
| [6]     | Reserved                                                                                                                                                                                                                                                                                                                   |

|       |                 |                                                                                                                                                               |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5]   | <b>DMALAST</b>  | <b>SHA/HMAC Last Block</b><br>This bit must be set as feeding in last byte of data.                                                                           |
| [4]   | <b>HMACEN</b>   | <b>HMAC_SHA Engine Operating Mode</b><br>0 = Execute SHA function.<br>1 = Execute HMAC function.                                                              |
| [3:2] | <b>Reserved</b> | Reserved.                                                                                                                                                     |
| [1]   | <b>STOP</b>     | <b>SHA/HMAC Engine Stop</b><br>0 = No effect.<br>1 = Stop SHA/HMAC engine.<br><b>Note:</b> This bit is always 0 when it's read back.                          |
| [0]   | <b>START</b>    | <b>SHA/HMAC Engine Start</b><br>0 = No effect.<br>1 = Start SHA/HMAC engine. BUSY flag will be set.<br><b>Note:</b> This bit is always 0 when it's read back. |

**SHA/HMAC Status Register (CRYPTO\_HMAC\_STS)**

| Register        | Offset          | R/W | Description          | Reset Value |
|-----------------|-----------------|-----|----------------------|-------------|
| CRYPTO_HMAC_STS | CRYPTO_BA+0x304 | R   | SHA/HMAC Status Flag | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                          |
| [16]    | DATINREQ    | <b>SHA/HMAC Non-dMA Mode Data Input Request</b><br>0 = No effect.<br>1 = Request SHA/HMAC Non-DMA mode data input.                 |
| [15:9]  | Reserved    | Reserved.                                                                                                                          |
| [8]     | DMAERR      | <b>SHA/HMAC Engine DMA Error Flag</b><br>0 = Show the SHA/HMAC engine access normal.<br>1 = Show the SHA/HMAC engine access error. |
| [7:2]   | Reserved    | Reserved.                                                                                                                          |
| [1]     | DMABUSY     | <b>SHA/HMAC Engine DMA Busy Flag</b><br>0 = SHA/HMAC DMA engine is idle or finished.<br>1 = SHA/HMAC DMA engine is busy.           |
| [0]     | BUSY        | <b>SHA/HMAC Engine Busy</b><br>0 = SHA/HMAC engine is idle or finished.<br>1 = SHA/HMAC engine is busy.                            |

**SHA/HMAC Outputs Digest Word Register (CRYPTO\_HMAC\_DGSTx)**

| Register            | Offset          | R/W | Description                | Reset Value |
|---------------------|-----------------|-----|----------------------------|-------------|
| CRYPTO_HMAC_D_GST0  | CRYPTO_BA+0x308 | R   | SHA/HMAC Digest Message 0  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST1  | CRYPTO_BA+0x30C | R   | SHA/HMAC Digest Message 1  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST2  | CRYPTO_BA+0x310 | R   | SHA/HMAC Digest Message 2  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST3  | CRYPTO_BA+0x314 | R   | SHA/HMAC Digest Message 3  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST4  | CRYPTO_BA+0x318 | R   | SHA/HMAC Digest Message 4  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST5  | CRYPTO_BA+0x31C | R   | SHA/HMAC Digest Message 5  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST6  | CRYPTO_BA+0x320 | R   | SHA/HMAC Digest Message 6  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST7  | CRYPTO_BA+0x324 | R   | SHA/HMAC Digest Message 7  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST8  | CRYPTO_BA+0x328 | R   | SHA/HMAC Digest Message 8  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST9  | CRYPTO_BA+0x32C | R   | SHA/HMAC Digest Message 9  | 0x0000_0000 |
| CRYPTO_HMAC_D_GST10 | CRYPTO_BA+0x330 | R   | SHA/HMAC Digest Message 10 | 0x0000_0000 |
| CRYPTO_HMAC_D_GST11 | CRYPTO_BA+0x334 | R   | SHA/HMAC Digest Message 11 | 0x0000_0000 |
| CRYPTO_HMAC_D_GST12 | CRYPTO_BA+0x338 | R   | SHA/HMAC Digest Message 12 | 0x0000_0000 |
| CRYPTO_HMAC_D_GST13 | CRYPTO_BA+0x33C | R   | SHA/HMAC Digest Message 13 | 0x0000_0000 |
| CRYPTO_HMAC_D_GST14 | CRYPTO_BA+0x340 | R   | SHA/HMAC Digest Message 14 | 0x0000_0000 |
| CRYPTO_HMAC_D_GST15 | CRYPTO_BA+0x344 | R   | SHA/HMAC Digest Message 15 | 0x0000_0000 |

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

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>DGST</b><br><b>SHA/HMAC Digest Message Output Register</b><br>For SHA-160, the digest is stored in CRYPTO_HMAC_DGST0 ~ CRYPTO_HMAC_DGST4.<br>For SHA-224, the digest is stored in CRYPTO_HMAC_DGST0 ~ CRYPTO_HMAC_DGST6.<br>For SHA-256, the digest is stored in CRYPTO_HMAC_DGST0 ~ CRYPTO_HMAC_DGST7.<br>For SHA-384, the digest is stored in CRYPTO_HMAC_DGST0 ~ CRYPTO_HMAC_DGST11.<br>For SHA-512, the digest is stored in CRYPTO_HMAC_DGST0 ~ CRYPTO_HMAC_DGST15. |

**SHA/HMAC Key Byte Count Register (CRYPTO\_HMAC\_KEYCNT)**

| Register           | Offset          | R/W | Description                      | Reset Value |
|--------------------|-----------------|-----|----------------------------------|-------------|
| CRYPTO_HMAC_KEYCNT | CRYPTO_BA+0x348 | R/W | SHA/HMAC Key Byte Count Register | 0x0000_0000 |

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

| Bits   | Description   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>KEYCNT</b> | <p><b>SHA/HMAC Key Byte Count</b></p> <p>The CRYPTO_HMAC_KEYCNT keeps the byte count of key that SHA/HMAC engine operates. The register is 32-bit and the maximum byte count is 4G bytes. It can be read and written.</p> <p>Writing to the register CRYPTO_HMAC_KEYCNT as the SHA/HMAC accelerator operating doesn't affect the current SHA/HMAC operation. But the value of CRYPTO_SHA_KEYCNT will be updated later on. Consequently, software can prepare the key count for the next SHA/HMAC operation.</p> |

**SHA/HMAC DMA Source Address Register (CRYPTO\_HMAC\_SADDR)**

| Register           | Offset          | R/W | Description                          |  |  |  | Reset Value |
|--------------------|-----------------|-----|--------------------------------------|--|--|--|-------------|
| CRYPTO_HMAC_SAD DR | CRYPTO_BA+0x34C | R/W | SHA/HMAC DMA Source Address Register |  |  |  | 0x0000_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] | SADDR       | <p><b>SHA/HMAC DMA Source Address</b></p> <p>The SHA/HMAC accelerator supports DMA function to transfer the plain text between SRAM memory space and embedded FIFO. The CRYPTO_HMAC_SADDR keeps the source address of the data buffer where the source text is stored. Based on the source address, the SHA/HMAC accelerator can read the plain text from SRAM memory space and do SHA/HMAC operation. The start of source address should be located at word boundary. In other words, bit 1 and 0 of CRYPTO_HMAC_SADDR are ignored.</p> <p>CRYPTO_HMAC_SADDR can be read and written. Writing to CRYPTO_HMAC_SADDR while the SHA/HMAC accelerator is operating doesn't affect the current SHA/HMAC operation. But the value of CRYPTO_HMAC_SADDR will be updated later on. Consequently, software can prepare the DMA source address for the next SHA/HMAC operation.</p> <p>In DMA mode, software can update the next CRYPTO_HMAC_SADDR before triggering START.</p> <p>Crypto_HMAC_SADDR and CRYPTO_HMAC_DADDR can be the same in the value.</p> |

**SHA/HMAC Byte Count Register (CRYPTO\_HMAC\_DMACNT)**

| Register           | Offset          | R/W | Description                  | Reset Value |
|--------------------|-----------------|-----|------------------------------|-------------|
| CRYPTO_HMAC_DMACNT | CRYPTO_BA+0x350 | R/W | SHA/HMAC Byte Count Register | 0x0000_0000 |

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

| Bits   | Description   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>DMACNT</b> | <p><b>SHA/HMAC Operation Byte Count</b></p> <p>The CRYPTO_HMAC_DMACNT keeps the byte count of source text that is for the SHA/HMAC engine operating in DMA mode. The CRYPTO_HMAC_DMACNT is 32-bit and the maximum of byte count is 4G bytes.</p> <p>CRYPTO_HMAC_DMACNT can be read and written. Writing to CRYPTO_HMAC_DMACNT while the SHA/HMAC accelerator is operating doesn't affect the current SHA/HMAC operation. But the value of CRYPTO_HMAC_DMACNT will be updated later on. Consequently, software can prepare the byte count of data for the next SHA/HMAC operation.</p> <p>In Non-DMA mode, CRYPTO_HMAC_DMACNT must be set as the byte count of the last block before feeding in the last block of data.</p> |

**SHA/HMAC Data Input Port Register (CRYPTO\_HMAC\_DATIN)**

| Register          | Offset          | R/W | Description                                           | Reset Value |
|-------------------|-----------------|-----|-------------------------------------------------------|-------------|
| CRYPTO_HMAC_DATIN | CRYPTO_BA+0x354 | R/W | SHA/HMAC Engine Non-DMA Mode Data Input Port Register | 0x0000_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       | <b>SHA/HMAC Engine Input Port</b><br>CPU feeds data to SHA/HMAC engine through this port by checking CRYPTO_HMAC_STS. Feed data as DATINREQ is 1. |

## 6.36.7.6 ECC Register

**ECC Control Register (CRYPTO\_ECC\_CTL)**

| Register       | Offset          | R/W | Description          |  |  |  | Reset Value |
|----------------|-----------------|-----|----------------------|--|--|--|-------------|
| CRYPTO_ECC_CTL | CRYPTO_BA+0x800 | R/W | ECC Control Register |  |  |  | 0x0000_0000 |

|          |          |     |       |     |       |       |      |
|----------|----------|-----|-------|-----|-------|-------|------|
| 31       | 30       | 29  | 28    | 27  | 26    | 25    | 24   |
| CURVEM   |          |     |       |     |       |       |      |
| 23       | 22       | 21  | 20    | 19  | 18    | 17    | 16   |
| CURVEM   |          | LDK | LDN   | LDB | LDA   | LDP2  | LDP1 |
| 15       | 14       | 13  | 12    | 11  | 10    | 9     | 8    |
| Reserved |          |     | MODOP |     | ECCOP |       | FSEL |
| 7        | 6        | 5   | 4     | 3   | 2     | 1     | 0    |
| DMAEN    | Reserved |     |       |     | STOP  | START |      |

| Bits    | Description                                                                                                                                                                                                                                                                |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | <b>CURVEM</b><br>The key length of elliptic curve.                                                                                                                                                                                                                         |
| [21]    | <b>LDK</b><br><b>The Control Signal of Register for SCALARK</b><br>0 = The register for SCALARK is not modified by DMA or user.<br>1 = The register for SCALARK is modified by DMA or user.                                                                                |
| [20]    | <b>LDN</b><br><b>The Control Signal of Register for the Parameter CURVEN of Elliptic Curve</b><br>0 = The register for CURVEN is not modified by DMA or user.<br>1 = The register for CURVEN is modified by DMA or user.                                                   |
| [19]    | <b>LDB</b><br><b>The Control Signal of Register for the Parameter CURVEB of Elliptic Curve</b><br>0 = The register for CURVEB is not modified by DMA or user.<br>1 = The register for CURVEB is modified by DMA or user.                                                   |
| [18]    | <b>LDA</b><br><b>The Control Signal of Register for the Parameter CURVEA of Elliptic Curve</b><br>0 = The register for CURVEA is not modified by DMA or user.<br>1 = The register for CURVEA is modified by DMA or user.                                                   |
| [17]    | <b>LDP2</b><br><b>The Control Signal of Register for the X and Y Coordinate of the Second Point (POINTX2, POINTY2)</b><br>0 = The register for POINTX2 and POINTY2 is not modified by DMA or user.<br>1 = The register for POINTX2 and POINTY2 is modified by DMA or user. |
| [16]    | <b>LDP1</b><br><b>The Control Signal of Register for the X and Y Coordinate of the First Point (POINTX1, POINTY1)</b><br>0 = The register for POINTX1 and POINTY1 is not modified by DMA or user.<br>1 = The register for POINTX1 and POINTY1 is modified by DMA or user.  |
| [15:13] | <b>Reserved</b><br>Reserved.                                                                                                                                                                                                                                               |

|         |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [12:11] | <b>MODOP</b>    | <b>Modulus Operation for PF</b><br>00 = Division :.<br>$\text{POINTX1} = (\text{POINTY1} / \text{POINTX1}) \% \text{CURVEN}$ .<br>01 = Multiplication :.<br>$\text{POINTX1} = (\text{POINTX1} * \text{POINTY1}) \% \text{CURVEN}$ .<br>10 = Addition :.<br>$\text{POINTX1} = (\text{POINTX1} + \text{POINTY1}) \% \text{CURVEN}$ .<br>11 = Subtraction :.<br>$\text{POINTX1} = (\text{POINTX1} - \text{POINTY1}) \% \text{CURVEN}$ .<br>MODOP is active only when ECCOP = 01.                                                                                                                                                                        |
| [10:9]  | <b>ECCOP</b>    | <b>Point Operation for BF and PF</b><br>00 = Point multiplication :.<br>$(\text{POINTX1}, \text{POINTY1}) = \text{SCALARK} * (\text{POINTX1}, \text{POINTY1})$ .<br>01 = Modulus operation : choose by MODOP (CRYPTO_ECC_CTL[12:11]).<br>10 = Point addition :.<br>$(\text{POINTX1}, \text{POINTY1}) = (\text{POINTX1}, \text{POINTY1}) + (\text{POINTX2}, \text{POINTY2})$<br>11 = Point doubling :.<br>$(\text{POINTX1}, \text{POINTY1}) = 2 * (\text{POINTX1}, \text{POINTY1})$ .<br>Besides above three input data, point operations still need the parameters of elliptic curve (CURVEA, CURVEB, CURVEN and CURVEM) as shown in Figure 6.27-11. |
| [8]     | <b>FSEL</b>     | <b>Field Selection</b><br>0 = Binary Field ( $\text{GF}(2^m)$ ).<br>1 = Prime Field ( $\text{GF}(p)$ ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [7]     | <b>DMAEN</b>    | <b>ECC Accelerator DMA Enable Bit</b><br>0 = ECC DMA engine Disabled.<br>1 = ECC DMA engine Enabled.<br>Only when START and DMAEN are 1, ECC DMA engine will be active                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [6:2]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [1]     | <b>STOP</b>     | <b>ECC Accelerator Stop</b><br>0 = No effect.<br>1 = Abort ECC accelerator and make it into idle state.<br>This bit is always 0 when it's read back.<br>Remember to clear ECC interrupt flag after stopping ECC accelerator.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]     | <b>START</b>    | <b>ECC Accelerator Start</b><br>0 = No effect.<br>1 = Start ECC accelerator. BUSY flag will be set.<br>This bit is always 0 when it's read back.<br>ECC accelerator will ignore this START signal when BUSY flag is 1.                                                                                                                                                                                                                                                                                                                                                                                                                               |

ECC Status Register (CRYPTO\_ECC\_STS)

| Register       | Offset          | R/W | Description         | Reset Value |
|----------------|-----------------|-----|---------------------|-------------|
| CRYPTO_ECC_STS | CRYPTO_BA+0x804 | R   | ECC 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 |    |    |    |    |    | DMABUSY | BUSY |

| Bits    | Description |                                                                                                                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                          |
| [16]    | BUSERR      | <b>ECC DMA Access Bus Error Flag</b><br>0 = No error.<br>1 = Bus error will stop DMA operation and ECC accelerator.                                                                                                                |
| [15:2]  | Reserved    | Reserved.                                                                                                                                                                                                                          |
| [1]     | DMABUSY     | <b>ECC DMA Busy Flag</b><br>0 = ECC DMA is idle or finished.<br>1 = ECC DMA is busy.                                                                                                                                               |
| [0]     | BUSY        | <b>ECC Accelerator Busy Flag</b><br>0 = The ECC accelerator is idle or finished.<br>1 = The ECC accelerator is under processing and protects all registers.<br>Remember to clear ECC interrupt flag after ECC accelerator finished |

**ECC the X-coordinate Value of the First Point Register (CRYPTO\_ECC\_X1)**

| Register         | Offset          | R/W | Description                                    | Reset Value |
|------------------|-----------------|-----|------------------------------------------------|-------------|
| CRYPTO_ECC_X1_00 | CRYPTO_BA+0x808 | R/W | ECC The X-coordinate word0 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_01 | CRYPTO_BA+0x80C | R/W | ECC The X-coordinate word1 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_02 | CRYPTO_BA+0x810 | R/W | ECC The X-coordinate word2 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_03 | CRYPTO_BA+0x814 | R/W | ECC The X-coordinate word3 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_04 | CRYPTO_BA+0x818 | R/W | ECC The X-coordinate word4 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_05 | CRYPTO_BA+0x81C | R/W | ECC The X-coordinate word5 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_06 | CRYPTO_BA+0x820 | R/W | ECC The X-coordinate word6 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_07 | CRYPTO_BA+0x824 | R/W | ECC The X-coordinate word7 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_08 | CRYPTO_BA+0x828 | R/W | ECC The X-coordinate word8 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_09 | CRYPTO_BA+0x82C | R/W | ECC The X-coordinate word9 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_X1_10 | CRYPTO_BA+0x830 | R/W | ECC The X-coordinate word10 of the first point | 0x0000_0000 |
| CRYPTO_ECC_X1_11 | CRYPTO_BA+0x834 | R/W | ECC The X-coordinate word11 of the first point | 0x0000_0000 |
| CRYPTO_ECC_X1_12 | CRYPTO_BA+0x838 | R/W | ECC The X-coordinate word12 of the first point | 0x0000_0000 |
| CRYPTO_ECC_X1_13 | CRYPTO_BA+0x83C | R/W | ECC The X-coordinate word13 of the first point | 0x0000_0000 |
| CRYPTO_ECC_X1_14 | CRYPTO_BA+0x840 | R/W | ECC The X-coordinate word14 of the first point | 0x0000_0000 |
| CRYPTO_ECC_X1_15 | CRYPTO_BA+0x844 | R/W | ECC The X-coordinate word15 of the first point | 0x0000_0000 |
| CRYPTO_ECC_X1_16 | CRYPTO_BA+0x848 | R/W | ECC The X-coordinate word16 of the first point | 0x0000_0000 |
| CRYPTO_ECC_X1_17 | CRYPTO_BA+0x84C | R/W | ECC The X-coordinate word17 of the first point | 0x0000_0000 |

|         |    |    |    |    |    |    |    |
|---------|----|----|----|----|----|----|----|
| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| POINTX1 |    |    |    |    |    |    |    |
| 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| POINTX1 |    |    |    |    |    |    |    |
| 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| POINTX1 |   |   |   |   |   |   |   |
|---------|---|---|---|---|---|---|---|
| 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| POINTX1 |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>POINTX1</b><br><br>ECC the x-coordinate Value of the First Point (POINTX1)<br>For B-163 or K-163, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_05<br>For B-233 or K-233, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_07<br>For B-283 or K-283, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_08<br>For B-409 or K-409, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_12<br>For B-571 or K-571, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_17<br>For P-192, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_05<br>For P-224, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_06<br>For P-256, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_07<br>For P-384, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_11<br>For P-521, POINTX1 is stored in CRYPTO_ECC_X1_00~CRYPTO_ECC_X1_16 |

ECC the Y-coordinate Value of the First Point Register (CRYPTO\_ECC\_Y1)

| Register         | Offset          | R/W | Description                                    | Reset Value |
|------------------|-----------------|-----|------------------------------------------------|-------------|
| CRYPTO_ECC_Y1_00 | CRYPTO_BA+0x850 | R/W | ECC The Y-coordinate word0 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_01 | CRYPTO_BA+0x854 | R/W | ECC The Y-coordinate word1 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_02 | CRYPTO_BA+0x858 | R/W | ECC The Y-coordinate word2 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_03 | CRYPTO_BA+0x85C | R/W | ECC The Y-coordinate word3 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_04 | CRYPTO_BA+0x860 | R/W | ECC The Y-coordinate word4 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_05 | CRYPTO_BA+0x864 | R/W | ECC The Y-coordinate word5 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_06 | CRYPTO_BA+0x868 | R/W | ECC The Y-coordinate word6 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_07 | CRYPTO_BA+0x86C | R/W | ECC The Y-coordinate word7 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_08 | CRYPTO_BA+0x870 | R/W | ECC The Y-coordinate word8 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_09 | CRYPTO_BA+0x874 | R/W | ECC The Y-coordinate word9 of the first point  | 0x0000_0000 |
| CRYPTO_ECC_Y1_10 | CRYPTO_BA+0x878 | R/W | ECC The Y-coordinate word10 of the first point | 0x0000_0000 |
| CRYPTO_ECC_Y1_11 | CRYPTO_BA+0x87C | R/W | ECC The Y-coordinate word11 of the first point | 0x0000_0000 |
| CRYPTO_ECC_Y1_12 | CRYPTO_BA+0x880 | R/W | ECC The Y-coordinate word12 of the first point | 0x0000_0000 |
| CRYPTO_ECC_Y1_13 | CRYPTO_BA+0x884 | R/W | ECC The Y-coordinate word13 of the first point | 0x0000_0000 |
| CRYPTO_ECC_Y1_14 | CRYPTO_BA+0x888 | R/W | ECC The Y-coordinate word14 of the first point | 0x0000_0000 |
| CRYPTO_ECC_Y1_15 | CRYPTO_BA+0x88C | R/W | ECC The Y-coordinate word15 of the first point | 0x0000_0000 |
| CRYPTO_ECC_Y1_16 | CRYPTO_BA+0x890 | R/W | ECC The Y-coordinate word16 of the first point | 0x0000_0000 |
| CRYPTO_ECC_Y1_17 | CRYPTO_BA+0x894 | R/W | ECC The Y-coordinate word17 of the first point | 0x0000_0000 |

|         |    |    |    |    |    |    |    |
|---------|----|----|----|----|----|----|----|
| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| POINTY1 |    |    |    |    |    |    |    |
| 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| POINTY1 |    |    |    |    |    |    |    |
| 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| POINTY1 |   |   |   |   |   |   |   |
|---------|---|---|---|---|---|---|---|
| 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| POINTY1 |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>POINTY1</b><br><br>ECC the Y-coordinate Value of the First Point (POINTY1)<br>For B-163 or K-163, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_05<br>For B-233 or K-233, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_07<br>For B-283 or K-283, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_08<br>For B-409 or K-409, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_12<br>For B-571 or K-571, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_17<br>For P-192, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_05<br>For P-224, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_06<br>For P-256, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_07<br>For P-384, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_11<br>For P-521, POINTY1 is stored in CRYPTO_ECC_Y1_00~CRYPTO_ECC_Y1_16 |

ECC the X-coordinate Value of the Second Point Register (CRYPTO\_ECC\_X2)

| Register         | Offset          | R/W | Description                                     | Reset Value |
|------------------|-----------------|-----|-------------------------------------------------|-------------|
| CRYPTO_ECC_X2_00 | CRYPTO_BA+0x898 | R/W | ECC The X-coordinate word0 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_01 | CRYPTO_BA+0x89C | R/W | ECC The X-coordinate word1 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_02 | CRYPTO_BA+0x8A0 | R/W | ECC The X-coordinate word2 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_03 | CRYPTO_BA+0x8A4 | R/W | ECC The X-coordinate word3 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_04 | CRYPTO_BA+0x8A8 | R/W | ECC The X-coordinate word4 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_05 | CRYPTO_BA+0x8AC | R/W | ECC The X-coordinate word5 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_06 | CRYPTO_BA+0x8B0 | R/W | ECC The X-coordinate word6 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_07 | CRYPTO_BA+0x8B4 | R/W | ECC The X-coordinate word7 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_08 | CRYPTO_BA+0x8B8 | R/W | ECC The X-coordinate word8 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_09 | CRYPTO_BA+0x8BC | R/W | ECC The X-coordinate word9 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_X2_10 | CRYPTO_BA+0x8C0 | R/W | ECC The X-coordinate word10 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_11 | CRYPTO_BA+0x8C4 | R/W | ECC The X-coordinate word11 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_12 | CRYPTO_BA+0x8C8 | R/W | ECC The X-coordinate word12 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_13 | CRYPTO_BA+0x8CC | R/W | ECC The X-coordinate word13 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_14 | CRYPTO_BA+0x8D0 | R/W | ECC The X-coordinate word14 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_15 | CRYPTO_BA+0x8D4 | R/W | ECC The X-coordinate word15 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_16 | CRYPTO_BA+0x8D8 | R/W | ECC The X-coordinate word16 of the second point | 0x0000_0000 |
| CRYPTO_ECC_X2_17 | CRYPTO_BA+0x8DC | R/W | ECC The X-coordinate word17 of the second point | 0x0000_0000 |

|         |    |    |    |    |    |    |    |
|---------|----|----|----|----|----|----|----|
| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| POINTX2 |    |    |    |    |    |    |    |
| 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| POINTX2 |    |    |    |    |    |    |    |
| 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| POINTX2 |   |   |   |   |   |   |   |
|---------|---|---|---|---|---|---|---|
| 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| POINTX2 |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>POINTX2</b><br><br>ECC the x-coordinate Value of the Second Point (POINTX2)<br>For B-163 or K-163, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_05<br>For B-233 or K-233, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_07<br>For B-283 or K-283, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_08<br>For B-409 or K-409, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_12<br>For B-571 or K-571, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_17<br>For P-192, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_05<br>For P-224, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_06<br>For P-256, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_07<br>For P-384, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_11<br>For P-521, POINTX2 is stored in CRYPTO_ECC_X2_00~CRYPTO_ECC_X2_16 |

ECC the Y-coordinate Value of the Second Point Register (CRYPTO\_ECC\_Y2)

| Register         | Offset          | R/W | Description                                     | Reset Value |
|------------------|-----------------|-----|-------------------------------------------------|-------------|
| CRYPTO_ECC_Y2_00 | CRYPTO_BA+0x8E0 | R/W | ECC The Y-coordinate word0 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_01 | CRYPTO_BA+0x8E4 | R/W | ECC The Y-coordinate word1 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_02 | CRYPTO_BA+0x8E8 | R/W | ECC The Y-coordinate word2 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_03 | CRYPTO_BA+0x8EC | R/W | ECC The Y-coordinate word3 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_04 | CRYPTO_BA+0x8F0 | R/W | ECC The Y-coordinate word4 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_05 | CRYPTO_BA+0x8F4 | R/W | ECC The Y-coordinate word5 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_06 | CRYPTO_BA+0x8F8 | R/W | ECC The Y-coordinate word6 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_07 | CRYPTO_BA+0x8FC | R/W | ECC The Y-coordinate word7 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_08 | CRYPTO_BA+0x900 | R/W | ECC The Y-coordinate word8 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_09 | CRYPTO_BA+0x904 | R/W | ECC The Y-coordinate word9 of the second point  | 0x0000_0000 |
| CRYPTO_ECC_Y2_10 | CRYPTO_BA+0x908 | R/W | ECC The Y-coordinate word10 of the second point | 0x0000_0000 |
| CRYPTO_ECC_Y2_11 | CRYPTO_BA+0x90C | R/W | ECC The Y-coordinate word11 of the second point | 0x0000_0000 |
| CRYPTO_ECC_Y2_12 | CRYPTO_BA+0x910 | R/W | ECC The Y-coordinate word12 of the second point | 0x0000_0000 |
| CRYPTO_ECC_Y2_13 | CRYPTO_BA+0x914 | R/W | ECC The Y-coordinate word13 of the second point | 0x0000_0000 |
| CRYPTO_ECC_Y2_14 | CRYPTO_BA+0x918 | R/W | ECC The Y-coordinate word14 of the second point | 0x0000_0000 |
| CRYPTO_ECC_Y2_15 | CRYPTO_BA+0x91C | R/W | ECC The Y-coordinate word15 of the second point | 0x0000_0000 |
| CRYPTO_ECC_Y2_16 | CRYPTO_BA+0x920 | R/W | ECC The Y-coordinate word16 of the second point | 0x0000_0000 |
| CRYPTO_ECC_Y2_17 | CRYPTO_BA+0x924 | R/W | ECC The Y-coordinate word17 of the second point | 0x0000_0000 |

|         |    |    |    |    |    |    |    |
|---------|----|----|----|----|----|----|----|
| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| POINTY2 |    |    |    |    |    |    |    |
| 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| POINTY2 |    |    |    |    |    |    |    |
| 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| POINTY2 |   |   |   |   |   |   |   |
|---------|---|---|---|---|---|---|---|
| 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| POINTY2 |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>POINTY2</b><br><br>ECC the Y-coordinate Value of the Second Point (POINTY2)<br>For B-163 or K-163, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_05<br>For B-233 or K-233, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_07<br>For B-283 or K-283, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_08<br>For B-409 or K-409, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_12<br>For B-571 or K-571, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_17<br>For P-192, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_05<br>For P-224, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_06<br>For P-256, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_07<br>For P-384, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_11<br>For P-521, POINTY2 is stored in CRYPTO_ECC_Y2_00~CRYPTO_ECC_Y2_16 |

ECC the Parameter CURVEA Value of Elliptic Curve Register (CRYPTO\_ECC\_A)

| Register       | Offset          | R/W | Description                                       | Reset Value |
|----------------|-----------------|-----|---------------------------------------------------|-------------|
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x928 | R/W | ECC The parameter CURVEA word0 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x92C | R/W | ECC The parameter CURVEA word1 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x930 | R/W | ECC The parameter CURVEA word2 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x934 | R/W | ECC The parameter CURVEA word3 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x938 | R/W | ECC The parameter CURVEA word4 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x93C | R/W | ECC The parameter CURVEA word5 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x940 | R/W | ECC The parameter CURVEA word6 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x944 | R/W | ECC The parameter CURVEA word7 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x948 | R/W | ECC The parameter CURVEA word8 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x94C | R/W | ECC The parameter CURVEA word9 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_A_0 | CRYPTO_BA+0x950 | R/W | ECC The parameter CURVEA word10 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_A_1 | CRYPTO_BA+0x954 | R/W | ECC The parameter CURVEA word11 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_A_1 | CRYPTO_BA+0x958 | R/W | ECC The parameter CURVEA word12 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_A_1 | CRYPTO_BA+0x95C | R/W | ECC The parameter CURVEA word13 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_A_1 | CRYPTO_BA+0x960 | R/W | ECC The parameter CURVEA word14 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_A_1 | CRYPTO_BA+0x964 | R/W | ECC The parameter CURVEA word15 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_A_1 | CRYPTO_BA+0x968 | R/W | ECC The parameter CURVEA word16 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_A_1 | CRYPTO_BA+0x96C | R/W | ECC The parameter CURVEA word17 of elliptic curve | 0x0000_0000 |

|        |    |    |    |    |    |    |    |
|--------|----|----|----|----|----|----|----|
| 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| CURVEA |    |    |    |    |    |    |    |
| 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CURVEA |    |    |    |    |    |    |    |
| 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| CURVEA |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|
| 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CURVEA |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <p><b>ECC the Parameter CURVEA Value of Elliptic Curve (CURVEA)</b></p> <p>The formula of elliptic curve is <math>y^2=x^3+CURVEA*x+CURVEB</math> in GF(p) and <math>y^2+x*y=x^3+CURVEA*x^2+CURVEB</math> in GF(<math>2^m</math>).</p> <p>For B-163 or K-163, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_05</p> <p>For B-233 or K-233, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_07</p> <p>For B-283 or K-283, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_08</p> <p>For B-409 or K-409, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_12</p> <p>For B-571 or K-571, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_17</p> <p>For P-192, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_05</p> <p>For P-224, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_06</p> <p>For P-256, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_07</p> <p>For P-384, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_11</p> <p>For P-521, CURVEA is stored in CRYPTO_ECC_A_00~CRYPTO_ECC_A_16</p> |

ECC the Parameter CURVEB Value of Elliptic Curve Register (CRYPTO\_ECC\_B)

| Register       | Offset          | R/W | Description                                       | Reset Value |
|----------------|-----------------|-----|---------------------------------------------------|-------------|
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x970 | R/W | ECC The parameter CURVEB word0 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x974 | R/W | ECC The parameter CURVEB word1 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x978 | R/W | ECC The parameter CURVEB word2 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x97C | R/W | ECC The parameter CURVEB word3 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x980 | R/W | ECC The parameter CURVEB word4 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x984 | R/W | ECC The parameter CURVEB word5 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x988 | R/W | ECC The parameter CURVEB word6 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x98C | R/W | ECC The parameter CURVEB word7 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x990 | R/W | ECC The parameter CURVEB word8 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_0 | CRYPTO_BA+0x994 | R/W | ECC The parameter CURVEB word9 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x998 | R/W | ECC The parameter CURVEB word10 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x99C | R/W | ECC The parameter CURVEB word11 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x9A0 | R/W | ECC The parameter CURVEB word12 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x9A4 | R/W | ECC The parameter CURVEB word13 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x9A8 | R/W | ECC The parameter CURVEB word14 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x9AC | R/W | ECC The parameter CURVEB word15 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x9B0 | R/W | ECC The parameter CURVEB word16 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_B_1 | CRYPTO_BA+0x9B4 | R/W | ECC The parameter CURVEB word17 of elliptic curve | 0x0000_0000 |

|        |    |    |    |    |    |    |    |
|--------|----|----|----|----|----|----|----|
| 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| CURVEB |    |    |    |    |    |    |    |
| 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CURVEB |    |    |    |    |    |    |    |
| 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| CURVEB |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|
| 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CURVEB |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>CURVEB</b><br><br>ECC the Parameter CURVEB Value of Elliptic Curve (CURVEA)<br>The formula of elliptic curve is $y^2=x^3+CURVEA*x+CURVEB$ in GF(p) and $y^2+x*y=x^3+CURVEA*x^2+CURVEB$ in GF( $2^m$ ).<br>For B-163 or K-163, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_05<br>For B-233 or K-233, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_07<br>For B-283 or K-283, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_08<br>For B-409 or K-409, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_12<br>For B-521 or K-521, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_17<br>For P-192, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_05<br>For P-224, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_06<br>For P-256, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_07<br>For P-384, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_11<br>For P-521, CURVEB is stored in CRYPTO_ECC_B_00~CRYPTO_ECC_B_16 |

ECC the Parameter CURVEN Value of Elliptic Curve Register (CRYPTO\_ECC\_N)

| Register       | Offset          | R/W | Description                                       | Reset Value |
|----------------|-----------------|-----|---------------------------------------------------|-------------|
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9B8 | R/W | ECC The parameter CURVEN word0 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9BC | R/W | ECC The parameter CURVEN word1 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9C0 | R/W | ECC The parameter CURVEN word2 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9C4 | R/W | ECC The parameter CURVEN word3 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9C8 | R/W | ECC The parameter CURVEN word4 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9CC | R/W | ECC The parameter CURVEN word5 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9D0 | R/W | ECC The parameter CURVEN word6 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9D4 | R/W | ECC The parameter CURVEN word7 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9D8 | R/W | ECC The parameter CURVEN word8 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_0 | CRYPTO_BA+0x9DC | R/W | ECC The parameter CURVEN word9 of elliptic curve  | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9E0 | R/W | ECC The parameter CURVEN word10 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9E4 | R/W | ECC The parameter CURVEN word11 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9E8 | R/W | ECC The parameter CURVEN word12 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9EC | R/W | ECC The parameter CURVEN word13 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9F0 | R/W | ECC The parameter CURVEN word14 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9F4 | R/W | ECC The parameter CURVEN word15 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9F8 | R/W | ECC The parameter CURVEN word16 of elliptic curve | 0x0000_0000 |
| CRYPTO_ECC_N_1 | CRYPTO_BA+0x9FC | R/W | ECC The parameter CURVEN word17 of elliptic curve | 0x0000_0000 |

|        |    |    |    |    |    |    |    |
|--------|----|----|----|----|----|----|----|
| 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| CURVEN |    |    |    |    |    |    |    |
| 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CURVEN |    |    |    |    |    |    |    |
| 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| CURVEN |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|
| 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CURVEN |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <p><b>ECC the Parameter CURVEN Value of Elliptic Curve (CURVEN)</b></p> <p>In GF(<math>p</math>), CURVEN is the prime <math>p</math>.</p> <p>In GF(<math>2^m</math>), CURVEN is the irreducible polynomial.</p> <p>For B-163 or K-163, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_05</p> <p>For B-233 or K-233, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_07</p> <p>For B-283 or K-283, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_08</p> <p>For B-409 or K-409, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_12</p> <p>For B-571 or K-571, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_17</p> <p>For P-192, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_05</p> <p>For P-224, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_06</p> <p>For P-256, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_07</p> <p>For P-384, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_11</p> <p>For P-521, CURVEN is stored in CRYPTO_ECC_N_00~CRYPTO_ECC_N_16</p> |

ECC the Scalar K Value of Elliptic Curve Register (CRYPTO\_ECC\_K)

| Register       | Offset          | R/W | Description                                           | Reset Value |
|----------------|-----------------|-----|-------------------------------------------------------|-------------|
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA00 | W   | ECC The scalar SCALARK word0 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA04 | W   | ECC The scalar SCALARK word1 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA08 | W   | ECC The scalar SCALARK word2 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA0C | W   | ECC The scalar SCALARK word3 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA10 | W   | ECC The scalar SCALARK word4 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA14 | W   | ECC The scalar SCALARK word5 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA18 | W   | ECC The scalar SCALARK word6 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA1C | W   | ECC The scalar SCALARK word7 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA20 | W   | ECC The scalar SCALARK word8 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_0 | CRYPTO_BA+0xA24 | W   | ECC The scalar SCALARK word9 of point multiplication  | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA28 | W   | ECC The scalar SCALARK word10 of point multiplication | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA2C | W   | ECC The scalar SCALARK word11 of point multiplication | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA30 | W   | ECC The scalar SCALARK word12 of point multiplication | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA34 | W   | ECC The scalar SCALARK word13 of point multiplication | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA38 | W   | ECC The scalar SCALARK word14 of point multiplication | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA3C | W   | ECC The scalar SCALARK word15 of point multiplication | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA40 | W   | ECC The scalar SCALARK word16 of point multiplication | 0x0000_0000 |
| CRYPTO_ECC_K_1 | CRYPTO_BA+0xA44 | W   | ECC The scalar SCALARK word17 of point multiplication | 0x0000_0000 |

|         |    |    |    |    |    |    |    |
|---------|----|----|----|----|----|----|----|
| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| SCALARK |    |    |    |    |    |    |    |
| 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SCALARK |    |    |    |    |    |    |    |
| 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  |

| SCALAR |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|
| 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SCALAR |   |   |   |   |   |   |   |

| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <p><b>SCALAR</b></p> <p>ECC the Scalar SCALAR Value of Point Multiplication(SCALAR)</p> <p>Because the SCALAR usually stores the private key, ECC accelerator do not allow to read the register SCALAR.</p> <p>For B-163 or K-163, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_05</p> <p>For B-233 or K-233, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_07</p> <p>For B-283 or K-283, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_08</p> <p>For B-409 or K-409, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_12</p> <p>For B-571 or K-571, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_17</p> <p>For P-192, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_05</p> <p>For P-224, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_06</p> <p>For P-256, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_07</p> <p>For P-384, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_11</p> <p>For P-521, SCALAR is stored in CRYPTO_ECC_K_00~CRYPTO_ECC_K_16</p> |

ECC DMA Source Address Register (CRYPTO\_ECC\_SADDR)

| Register          | Offset          | R/W | Description                     | Reset Value |
|-------------------|-----------------|-----|---------------------------------|-------------|
| CRYPTO_ECC_SAD DR | CRYPTO_BA+0xA48 | R/W | ECC DMA Source Address Register | 0x0000_0000 |



| Bits   | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | <b>Reserved</b> | <b>ECC DMA Source Address</b><br>The ECC accelerator supports DMA function to transfer the DATA and PARAMETER between SRAM memory space and ECC accelerator. The SADDR keeps the source address of the data buffer where the source text is stored. Based on the source address, the ECC accelerator can read the DATA and PARAMETER from SRAM memory space and do ECC operation. The start of source address should be located at word boundary. That is, bit 1 and 0 of SADDR are ignored. SADDR can be read and written. In DMA mode, software must update the CRYPTO_ECC_SADDR before triggering START. |

ECC DMA Destination Address Register (CRYPTO\_ECC\_DADDR)

| Register          | Offset          | R/W | Description                          | Reset Value |
|-------------------|-----------------|-----|--------------------------------------|-------------|
| CRYPTO_ECC_DAD DR | CRYPTO_BA+0xA4C | R/W | ECC DMA Destination Address Register | 0x0000_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 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | DADDR       | <p><b>ECC DMA Destination Address</b></p> <p>The ECC accelerator supports DMA function to transfer the DATA and PARAMETER between SRAM memory and ECC accelerator. The DADDR keeps the destination address of the data buffer where output data of ECC engine will be stored. Based on the destination address, the ECC accelerator can write the result data back to SRAM memory space after the ECC operation is finished. The start of destination address should be located at word boundary. That is, bit 1 and 0 of DADDR are ignored. DADDR can be read and written. In DMA mode, software must update the CRYPTO_ECC_DADDR before triggering START.</p> |

**ECC Starting Address of Updated Registers (CRYPTO\_ECC\_STARTREG)**

| Register                | Offset              | R/W | Description                               |  |  |  | Reset Value |
|-------------------------|---------------------|-----|-------------------------------------------|--|--|--|-------------|
| CRYPTO_ECC_STA<br>RTREG | CRYPTO_BA+0xA<br>50 | R/W | ECC Starting Address of Updated Registers |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | STARTREG    | <b>ECC Starting Address of Updated Registers</b><br>The address of the updated registers that DMA feeds the first data or parameter to ECC engine. When ECC engine is active, ECC accelerator does not allow users to modify STARTREG, for example, to update input data from register CRYPTO_ECC_POINTX1. Thus, the value of STARTREG is 0x808. |

ECC DMA Word Count r (CRYPTO\_ECC\_WORDCNT)

| Register               | Offset              | R/W | Description        |  |  | Reset Value |
|------------------------|---------------------|-----|--------------------|--|--|-------------|
| CRYPTO_ECC_WO<br>RDCNT | CRYPTO_BA+0xA<br>54 | R/W | ECC DMA Word Count |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                     |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | WORDCNT     | <p><b>ECC DMA Word Count</b></p> <p>The CRYPTO_ECC_WORDCNT keeps the word count of source data that is for the required input data of ECC accelerator with various operations in DMA mode. Although CRYPTO_ECC_WORDCNT is 32-bit, the maximum of word count in ECC accelerator is 144 words.</p> <p>CRYPTO_ECC_WORDCNT can be read and written.</p> |

## 6.37 Enhanced 12-bit Analog-to-Digital Converter (EADC)

### 6.37.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, PWM0/1 triggers, BPWM0/1 triggers, timer0~3 overflow pulse triggers, ADINT0, ADINT1 interrupt EOC (End of conversion) pulse trigger and external pin (EADC0\_ST) input signal.

### 6.37.2 Features

- Analog input voltage range: 0~  $V_{REF}$  (Max to 3.6V)
- Reference voltage from  $V_{REF}$  pin
- 12-bit resolution and 10-bit accuracy is guaranteed
- Up to 16 single-end analog external input channels or 8 pair differential analog input channels
- Up to 3 internal channels, they are band-gap voltage ( $V_{BG}$ ), temperature sensor ( $V_{TEMP}$ ), and  $V_{DD}$  power
- Four ADC interrupts (ADINT0~3) with individual interrupt vector addresses
- Maximum ADC clock frequency is 72 MHz
- Up to 5.14 MSPS conversion rate
- Configurable ADC internal sampling time.
- 12-bit, 10-bit, 8-bit, 6-bit configurable resolution.
- Supports calibration and load calibration words capability.
- Supports internal reference voltage  $V_{REF}$ : 1.6V, 2.0V, 2.5V, and 3.0V.
- Supports three power saving modes:
  - Deep Power-down mode
  - Power-down mode
  - Standby mode
- Up to 19 sample modules
  - Each of sample modules which is configurable for ADC converter channel EADC\_CH0~15 and trigger source
  - Sample module 16~18 is fixed for ADC channel 16, 17, 18 input sources as band-gap voltage, temperature sensor, and  $V_{DD}$  power.
  - Double buffer for sample control logic module 0~3
  - Configurable sampling time for each sample module
  - Conversion results are held in 19 data registers with valid and overrun indicators
- An ADC conversion can be started by:
  - Write 1 to SWTRGn (EADC\_SWTRG[n], n = 0~18)
  - External pin EADC0\_ST
  - Timer0~3 overflow pulse triggers
  - ADINT0 and ADINT1 interrupt EOC (End of conversion) pulse triggers
  - EPWM/BPWM triggers

- Supports PDMA transfer
- Conversion Result Monitor by Compare Mode

### 6.37.3 Block Diagram



Figure 6.37-1 ADC Converter Block Diagram

### 6.37.4 Basic Configuration

- Clock source Configuration
  - Select the clock divider number on EADCDIV (CKL\_CLKDIV0[23:16])
  - Enable EADC peripheral clock in EADCCKEN (CLK\_APBCLK0[28]).
- Reset Configuration
  - Reset EADC controller in ADRST (EADC\_CTL [1]).
- Pin configuration

| Group | Pin Name | GPIO | MFP |
|-------|----------|------|-----|
|-------|----------|------|-----|

|          |              |       |      |
|----------|--------------|-------|------|
| EADC0    | EADC0_CH0    | PB.0  | MFP1 |
|          | EADC0_CH1    | PB.1  | MFP1 |
|          | EADC0_CH2    | PB.2  | MFP1 |
|          | EADC0_CH3    | PB.3  | MFP1 |
|          | EADC0_CH4    | PB.4  | MFP1 |
|          | EADC0_CH5    | PB.5  | MFP1 |
|          | EADC0_CH6    | PB.6  | MFP1 |
|          | EADC0_CH7    | PB.7  | MFP1 |
|          | EADC0_CH8    | PB.8  | MFP1 |
|          | EADC0_CH9    | PB.9  | MFP1 |
|          | EADC0_CH10   | PB.10 | MFP1 |
|          | EADC0_CH11   | PB.11 | MFP1 |
|          | EADC0_CH12   | PB.12 | MFP1 |
|          | EADC0_CH13   | PB.13 | MFP1 |
|          | EADC0_CH14   | PB.14 | MFP1 |
|          | EADC0_CH15   | PB.15 | MFP1 |
| EADC0_ST | PF.5         | MFP11 |      |
|          | PC.13, PD.12 | MFP14 |      |
|          | PG.15        | MFP15 |      |

### 6.37.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~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~3 and sample module 4~15 are shows as follows.



Figure 6.37-2 Sample Module 0~3 Block Diagram



Figure 6.37-3 Sample Module 4~15 Block Diagram

Sample module 16~18 can convert internal channel ( $V_{BG}$ ,  $V_{TEMP}$ ,  $V_{DD}$ ) and can be triggered by user write SWTRGn (EADC\_SWTRG[n], n = 16~18). Figure 6.37-4 shows the sample module 16~18.



Figure 6.37-4 Sample Module 16~18 Block Diagram

The ADC conversion trigger sources in sample module 0~15 are listed below:

- Write 1 to SWTRGn (EADC\_SWTRG[n], n = 0~15)

- External pin EADC0\_ST
- Timer0~3 overflow pulse triggers
- ADINT0, ADINT1 ADC interrupt EOC (End of conversion) pulse triggers
- EPWM/BPWM 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.37.5.1 ADC Clock Generator

The maximum EADC clock frequency is up to 72 MHz and the maximum sampling rate is up to 5.14 MSPS.

The clock control of EADC is shown as Figure 6.37-5. The EADC peripheral clock source is from HCLK clock, the ADC clock frequency is divided by an 8-bit pre-scalar with the following formula:

$$\text{EADC clock frequency} = (\text{PCLK1}) / (\text{EADCDIV} (\text{CLK_CLKDIV0}[23:16]) + 1)$$



Figure 6.37-5 EADC Clock Control

#### 6.37.5.2 ADC Software Trigger Mode

When a ADC 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], n=0~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 ADC data register EADC\_DATn (n=0~18) corresponding to the sample module.
3. On completion of conversion, the ADIFn (EADC\_STATUS2[3:0], n=0~3) is set to 1 and ADC interrupt (ADINTn, n=0~3) is requested if the ADCIENn (EADC\_CTL[5:2], n=0~3) bit is set to 1.
4. The SWTRGn (n=0~18) bit remains 1 during ADC conversion. When ADC conversion ends, the SWTRGn (n=0~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.37-6.



Figure 6.37-6 Example ADC Conversion Timing Diagram, n=0~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.

**Note:** If the interval between next conversion is more than 100 us, ADC would enter idle state automatically. User needs to execute a dummy conversion before normal operation. In other words, the first conversion result is incorrect when ADC is in idle state.

#### 6.37.5.3 ADC 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. Sample module with lower number has higher priority than the higher number sample module. The priority of sample module is shown as Figure 6.37-7. When more than one Sample Module are triggered at the same time, the Sample Module with lower number will start to convert first. The other Sample Module will be in the queue and the corresponding pending flag STPF(EADC\_PENDSTS[n], n=0~18) are set to 1 by HW. After the Sample Module finish the conversion, STPF(EADC\_PENDSTS[n], n=0~18) will be set to 0 automatically. If the Sample Module which is in the queue is triggered once more, the corresponding Overrun Flag SPOVF(EADC\_OVSTS[n], n=0~18) will be set to 1 by HW.

For example, the Sample Module 0, 2, 3, 5 are triggered simultaneously. The input channel of Sample Module 0 will be converted first. Sample Module 2, 3, 5 will be suspended and STPF (EADC\_PENDSTS[2], EADC\_PENDSTS [3], EADC\_PENDSTS [5]) will be set to 1. If Sample Module 5 is trigger once more in the same time, SPOVF(EADC\_OVSTS[5]) will be set to 1.



Figure 6.37-7 Sample Module Conversion Priority Arbitrator Diagram

#### 6.37.5.4 Conversion Cycles and Sampling Rate Frequency

There are four kinds of resolutions which could be configured by RESSEL (EADC\_CTL[7:6]). Each resolution corresponds to different conversion cycles. The relation is as Table 6.37-1.

| Resolution | Minimum Conversion Cycles |
|------------|---------------------------|
| 6 bit      | 8 ADC_CLK                 |
| 8 bit      | 10 ADC_CLK                |
| 10 bit     | 12 ADC_CLK                |
| 12 bit     | 14 ADC_CLK                |

Table 6.37-1 Relation between Resolution and Conversion Cycles

There are two kinds of analog input channels which are fast and slow channel. EADC\_CH10~15 are fast channel and EADC\_CH0~9 are slow channel. The maximum sampling rate of fast channel is 5.14 MSPS and slow channel is 2.14 MSPS. Exceed the limitation of sampling frequency will cause wrong conversion results. The sampling rate frequency can be computed with the following formula:

$$\text{Sampling rate frequency} = (\text{EADC clock frequency}) / (\text{conversion cycles})$$

#### 6.37.5.5 Maximum Sampling Frequency Conversion by Software Trigger

If user needs to scan the fast channel at maximum sampling frequency, the conversion needs to be executed by the condition as: multiple sample modules, triggered by software, and triggered repeatedly during the last conversion. An example of continuous scan is as follows:

1. Using Module 0~15 to carry out successive conversion. Set CHSEL (EADC\_SCTL0~15[3:0]) as one of fast channel (EADC\_CH10~ EADC\_CH15). Set EXTSMPT (EADC\_SCTL0~15[31:24]) and TRGDLYCNT (EADC\_SCTL0~15[15:8]) as 0x00 to minimize the sampling time.
2. Set SWTRG (EADC\_SWTRG[18:0]) as 0xffff to trigger Module 0~15.
3. Wait CURSPL (EADC\_STATUS3[4:0]) changes to 0xf which means Module 0~14 have been executed and Module 15 is in the process. Set SWTRG (EADC\_SWTRG[18:0]) as 0x7fff to trigger Module 0~14 again for next round.
4. Wait CURSPL (EADC\_STATUS3[4:0]) changes to 0x1, set SWTRG (EADC\_SWTRG[18:0]) as 0x8000 to trigger Module 15.
5. Repeat Step 3~4 to continue the conversion.

#### 6.37.5.6 ADC Sample Module End of Conversion Interrupt Operation

There are 4 ADC interrupts ADINT0~3, and each of these interrupts has its own interrupt vector address and can be configured to set multiple sample module EOC pulse (sample module 0~18 End of conversion pulses) as its interrupt trigger source. Figure 6.37-8 shows the control logic of interrupts. Take ADINT0 as an example, when ADCIEN0 (EADC\_CTL[2]) = 1 and SPLIE<sub>n</sub> (EADC\_INTSRC0[n]) = 1 (n=0~18), the specific module EOC (End of conversion) pulses will set flag ADIF0 (EADC\_STATUS[0]) as 1 and interrupt (ADINT0) will be asserted either.

The interrupt pulses (ADINT0/1) are generated whenever the specific sample module ADC EOC pulse is generated. It also can be the sample module conversion trigger sources, and user can use it to do the ADC continuous scan conversion.

The example of continuous scan triggered by interrupt is as follows:

1. If ADC sample module 2 EOC2 pulse is selected as ADINT0 interrupt trigger SPLIE2 (EADC\_INTSRC0[2]) = 1 and ADINT0 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 ADC conversion, after the conversion completes, it generates an EOC2 pulse signal and ADINT0 interrupt pulse at end of sample module 2 ADC conversion, ADINT0 interrupt pulse will trigger the sample module 0, 1, 2 to start the ADC conversions.
3. ADINT0 interrupt pulse repeats to trigger sample module 0, 1, 2 ADC 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.

**Note:** Because the system costs 3 ADC\_CLK to trigger next module by interrupt pulse, the average conversion cycles of continuous scan triggered by interrupt is 17 ADC\_CLK.



Figure 6.37-8 Specific Sample Module ADC EOC Signal for ADINT0~3 Interrupt

#### 6.37.5.7 ADC Trigger by Timer Trigger and External Pin EADC0\_ST

There are 4 Timer trigger source and an external pin EADC0\_ST which can configure sample module 0~15 to trigger ADC start when Timer overflow occurs.

#### 6.37.5.8 ADC Start Synchronous with PWM/BPWM Trigger

Besides user start, ADINT0/1 interrupt pulse, external pin EADC0\_ST and Timer0~3 overflow pulse to start ADC conversion, this device has new feature to allow PWM/BPWM channels to trigger the ADC start. User may configure PWM/BPWM trigger types: rising, falling PWM/BPWM edge or center point of PWM/BPWM (center-aligned mode only) to trigger ADC start. The device also allows user to configure the amount of delay period to ADC start after hardware detected the external trigger. User can configure the trigger delay time by setting TRGDLYCNT (EADC\_SCTLn[15:8], n=0~15) and TRGDLYDIV (EADC\_SCTLn[7:6], n=8~15). Figure 6.37-9 shows the programmable delay time for PWM/BPWM-triggered ADC start conversion.

Figure 6.37-10 shows the programmable delay time for other trigger source.



Figure 6.37-9 EPWM-triggered ADC Start Conversion



Figure 6.37-10 External triggered ADC Start Conversion

#### 6.37.5.9 ADC Conversion Time and External Trigger

The ADC converter sample the analog input when ADC conversion start delay time ( $T_d$ ) has passed after SWTRGn (EADC\_SWTRG[n], n=0~18) is set to 1, then start conversion. Due to ADC clock is generated by PCLK divided by (ADC(CLKDIV[23:16])+1), the maximum delay time from user write SWTRGn to ADC start sampling analog input time is two ADC clock cycles. The start delay time is shown in Figure 6.37-11.

ADC conversion can be triggered by external pin EADC0\_ST request. Setting the TRGSEL (EADC\_SCTLn[20:16], n=0~15) to 0x01 is to select external trigger input from the EADC0\_ST pin. User can set EXTFEN (EADC\_SCTLn[5], n=0~15) and EXTREN (EADC\_SCTLn[4], n=0~15) 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.37-12.



Figure 6.37-11 Conversion Start Delay Timing Diagram



Figure 6.37-12 EADC0\_ST De-bounce Timing Diagram

#### 6.37.5.10 ADC Extend Sampling Time

When ADC operates at high ADC 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], n=0~15) for each sample module. The ADC extend sampling time is present between ADC controller judge which channel to be converting and ADC start to conversion. The range of extend sampling time is from 0 ~255 ADC clock. The extended sampling time is shown in Figure 6.37-13.



Figure 6.37-13 ADC Extend Sampling Timing Diagram

#### 6.37.5.11 Conversion Result Monitor by Compare Mode

The ADC controller provides four sets of compare registers EADC\_CMP0 ~ EADC\_CMP3 to monitor a maximum of four specified sample module 0~18 conversion results from ADC conversion module, as shown in Figure 6.37-14. User can select which sample module result to be monitored by set CMPSPL (EADC\_CMPn[7:3], n =0~3) and CMPCOND (EADC\_CMPn[2], where n =0~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~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 n =0~3) then ADCMPFn (EADC\_STATUS2[7:4], where n =0~3) bit will be set to 1, if ADCMPIE (EADC\_CMPn[1], n =0~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.37-14.



Figure 6.37-14 ADC Conversion Result Monitor Logics Diagram

The ADC controller supports a window compare mode. User can set CMPWEN (EADC\_CMP0[15]/EADC\_CMP2[15]) to enable this function. If user enables this function, ADCMPF0 (EADC\_STATUS2[4]) will be set when both EADC\_CMP0 and EADC\_CMP1 compared condition matched. ADCMPF2 (EADC\_STATUS2[6]) will be set when both EADC\_CMP2 and EADC\_CMP3 compared condition matched.

#### 6.37.5.12 Differential Mode

The ADC controller supports analog differential mode. If user enables DIFFEN (EADC\_CTL[8]), the differential mode will enable. The pair of analog input channel is as Table 6.37-2.

Differential analog input voltage ( $V_{diff}$ ) =  $V_{plus} - V_{minus}$ , where  $V_{plus}$  is the analog input;  $V_{minus}$  is the inverted analog input.

| Differential Analog Input Paired Channel | ADC Analog Input |             |
|------------------------------------------|------------------|-------------|
|                                          | $V_{plus}$       | $V_{minus}$ |
| 0                                        | EADC_CH0         | EADC_CH1    |
| 1                                        | EADC_CH2         | EADC_CH3    |
| 2                                        | EADC_CH4         | EADC_CH5    |
| 3                                        | EADC_CH6         | EADC_CH7    |
| 4                                        | EADC_CH8         | EADC_CH9    |
| 5                                        | EADC_CH10        | EADC_CH11   |
| 6                                        | EADC_CH12        | EADC_CH13   |
| 7                                        | EADC_CH14        | EADC_CH15   |

Table 6.37-2 EADC Differential Model Channel Selection

In differential analog input mode, only the even number of the two corresponding channels needs to be enabled in CHSEL (EADC\_SCTLn[3:0]). The conversion result will be placed to the corresponding data register of the enabled channel. The conversion result will store with 2'complement format when DMOF (EADC\_CTL[9]) = 1.

#### 6.37.5.13 Double Buffer Mode

The ADC controller supports a double buffer mode in sample module 0~3. If user enable DBMEN (EADC\_SCTLn[23], n=0~3), the double buffer mode will enable. In double buffer mode, after first time ADC convert finish, the VALID (EADC\_DATn[17], n=0~3) will set to high, but VALID (EADC\_DDATn[17], n=0~3) will keep low. And the second time ADC converts finish, VALID (EADC\_DDATn[17], n=0~3) will set to high either. Then, user can get the ADC results from

EADC\_DATn and EADC\_DDATn register.

#### 6.37.5.14 PDMA Request

The ADC controller supports PDMA. User can enable PDMAEN (EADC\_CTL[11]) and configure PDMA channel's source address as EADC\_CURDAT (EADC\_BA+0x4C). After enable PDMAEN and PDMA channel enable, if any VALID (EADC\_DATn[17], n=0~18) is high, ADC 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.37.5.15 Interrupt Sources

The ADC converter generates ADIFn (EADC\_STATUS2[3:0], n=0~3) at the start of conversion or the end of conversion decide by INTPOS (EADC\_SCTLn[22], n=0~15). If ADCIEnn (EADC\_CTL[5:2], n=0~3) is set then conversion end interrupt request ADINTn (n=0~3) is generated. The controller of interrupts is shown as Figure 6.37-15.



Figure 6.37-15 ADC Controller Interrupts

#### 6.37.5.16 Power Management and Calibration

There are three kinds of power saving mode which are Deep Power-down, Power-down, and Standby. User may set PWDMOD (EADC\_PWRM[3:2]) to select which power saving mode EADC would enter when ADCEN (EADC\_CTL[0]) is set as 0. The difference of these Power-down mode is shown as Table 6.37-3. Because the internal LDO will be shut down in Deep Power-down and Power-down mode, EADC needs to take extra time to resume. The interval of time to resume is set by LDOSUT (EADC\_PWRM[19:8]) which must be longer than 20 us. As for the Standby mode, LDO will keep enable and start-up time is unnecessary.

| Power Supplies        | Deep Power-Down | Power-Down | Standby |
|-----------------------|-----------------|------------|---------|
| Internal LDO          | Disable         | Disable    | Enable  |
| Internal power switch | Disable         | Enable     | Enable  |

Table 6.37-3 EADC Power Saving Mode

When EADC is activated by setting ADCEN(EADC\_CTL[0]) to 1, the start up sequence will execute automatically. After start up sequence finished, PWUPRDY (EADC\_PWRM[0]) will be set to 1 by HW which means ready to convert. ADCEN (EADC\_CTL[0]) must be kept at 1 until PWUPRDY (EADC\_PWRM[0]) is set to 1 during the start up sequence. Changing ADCEN (EADC\_CTL[0]) arbitrarily at start up sequence will cause EADC function failure.

The conversion results of ADC will be more accurate with calibration. User may set PWUCALEN (EADC\_PWRM[1]) as 1 to carry out calibration at start up. This bit needs to cooperate with CALSEL (EADC\_CALCTL [3]), the configuration of {PWUCALEN, CALSEL} is shown as Table 6.37-4. An example about start up with calibration is shown as Figure 6.37-16.

| PWUCALEN | CALSEL | Configuration                     |
|----------|--------|-----------------------------------|
| 0        | 0      | Start up without calibration      |
| 0        | 1      | Start up without calibration      |
| 1        | 0      | Load calibration word at start up |
| 1        | 1      | Start up with calibration         |

Table 6.37-4 EADC Start up with Calibration



Figure 6.37-16 ADC Start up Sequence with Calibration

To get precise result, user may calibrate again after a few conversion. Set CALSTART (EADC\_CALCTL[1]) as 1 could enable calibration again, but this bit needs to work with CALSEL (EADC\_CALCTL[3]). Before set CALSTART (EADC\_CALCTL[1]) as 1 to start calibration again, EADCDIV (CKL\_CLKDIV0[23:16]) must be 0. Set CALSTART (EADC\_CALCTL[1]) as 1 and CALSEL (EADC\_CALCTL[3]) as 1 will execute calibration again then update CALWORD (EADC\_CALDWRD[6:0]). Set CALSTART (EADC\_CALCTL[1]) as 1 and CALSEL (EADC\_CALCTL[3]) as 0 will load CALWORD (EADC\_CALDWRD[6:0]) which was defined by user. The re-calibration

sequence should be as follows:

1. Set CALSEL (EADC\_CALCTL[3]) as 1 or 0 to select calibration function
2. Set CALSTART (EADC\_CALCTL[1]) as 1 to active calibration
3. CALDONE (EADC\_CALCTL[2]) will be set as 0 by HW during calibration
4. Wait for CALDONE (EADC\_CALCTL[2]) is set as 1 by HW. If CALSEL (EADC\_CALCTL[3]) is set as 1, the new calibration word will be updated to CALWORD (EADC\_CALDWRD[6:0]). If CALSEL (EADC\_CALCTL[3]) is set as 0, the specific CALWORD (EADC\_CALDWRD[6:0]) was loaded rather than executing calibration.

**Note:** Before set CALSTART (EADC\_CALCTL[1]) as 1 to start calibration again, EADCDIV (CKL\_CLKDIV0[23:16]) must be 0.

### 6.37.6 Register Map

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

| Register                     | Offset       | R/W | Description                                                 | Reset Value |
|------------------------------|--------------|-----|-------------------------------------------------------------|-------------|
| <b>EADC Base Address:</b>    |              |     |                                                             |             |
| <b>EADC_BA = 0x4004_3000</b> |              |     |                                                             |             |
| <b>EADC_DAT0</b>             | EADC_BA+0x00 | R   | ADC Data Register 0 for Sample Module 0                     | 0x0000_0000 |
| <b>EADC_DAT1</b>             | EADC_BA+0x04 | R   | ADC Data Register 1 for Sample Module 1                     | 0x0000_0000 |
| <b>EADC_DAT2</b>             | EADC_BA+0x08 | R   | ADC Data Register 2 for Sample Module 2                     | 0x0000_0000 |
| <b>EADC_DAT3</b>             | EADC_BA+0x0C | R   | ADC Data Register 3 for Sample Module 3                     | 0x0000_0000 |
| <b>EADC_DAT4</b>             | EADC_BA+0x10 | R   | ADC Data Register 4 for Sample Module 4                     | 0x0000_0000 |
| <b>EADC_DAT5</b>             | EADC_BA+0x14 | R   | ADC Data Register 5 for Sample Module 5                     | 0x0000_0000 |
| <b>EADC_DAT6</b>             | EADC_BA+0x18 | R   | ADC Data Register 6 for Sample Module 6                     | 0x0000_0000 |
| <b>EADC_DAT7</b>             | EADC_BA+0x1C | R   | ADC Data Register 7 for Sample Module 7                     | 0x0000_0000 |
| <b>EADC_DAT8</b>             | EADC_BA+0x20 | R   | ADC Data Register 8 for Sample Module 8                     | 0x0000_0000 |
| <b>EADC_DAT9</b>             | EADC_BA+0x24 | R   | ADC Data Register 9 for Sample Module 9                     | 0x0000_0000 |
| <b>EADC_DAT10</b>            | EADC_BA+0x28 | R   | ADC Data Register 10 for Sample Module 10                   | 0x0000_0000 |
| <b>EADC_DAT11</b>            | EADC_BA+0x2C | R   | ADC Data Register 11 for Sample Module 11                   | 0x0000_0000 |
| <b>EADC_DAT12</b>            | EADC_BA+0x30 | R   | ADC Data Register 12 for Sample Module 12                   | 0x0000_0000 |
| <b>EADC_DAT13</b>            | EADC_BA+0x34 | R   | ADC Data Register 13 for Sample Module 13                   | 0x0000_0000 |
| <b>EADC_DAT14</b>            | EADC_BA+0x38 | R   | ADC Data Register 14 for Sample Module 14                   | 0x0000_0000 |
| <b>EADC_DAT15</b>            | EADC_BA+0x3C | R   | ADC Data Register 15 for Sample Module 15                   | 0x0000_0000 |
| <b>EADC_DAT16</b>            | EADC_BA+0x40 | R   | ADC Data Register 16 for Sample Module 16                   | 0x0000_0000 |
| <b>EADC_DAT17</b>            | EADC_BA+0x44 | R   | ADC Data Register 17 for Sample Module 17                   | 0x0000_0000 |
| <b>EADC_DAT18</b>            | EADC_BA+0x48 | R   | ADC Data Register 18 for Sample Module 18                   | 0x0000_0000 |
| <b>EADC_CURDAT</b>           | EADC_BA+0x4C | R   | ADC PDMA Current Transfer Data Register                     | 0x0000_0000 |
| <b>EADC_CTL</b>              | EADC_BA+0x50 | R/W | ADC Control Register                                        | 0x0000_00C0 |
| <b>EADC_SWTRG</b>            | EADC_BA+0x54 | W   | ADC Sample Module Software Start Register                   | 0x0000_0000 |
| <b>EADC_PENDSTS</b>          | EADC_BA+0x58 | R/W | ADC Start of Conversion Pending Flag Register               | 0x0000_0000 |
| <b>EADC_OVSTS</b>            | EADC_BA+0x5C | R/W | ADC Sample Module Start of Conversion Overrun Flag Register | 0x0000_0000 |
| <b>EADC_SCTL0</b>            | EADC_BA+0x80 | R/W | ADC Sample Module 0 Control Register                        | 0x0000_0000 |
| <b>EADC_SCTL1</b>            | EADC_BA+0x84 | R/W | ADC Sample Module 1 Control Register                        | 0x0000_0000 |

| Register                     | Offset       | R/W | Description                                     | Reset Value |
|------------------------------|--------------|-----|-------------------------------------------------|-------------|
| <b>EADC Base Address:</b>    |              |     |                                                 |             |
| <b>EADC_BA = 0x4004_3000</b> |              |     |                                                 |             |
| <b>EADC_SCTL2</b>            | EADC_BA+0x88 | R/W | ADC Sample Module 2 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL3</b>            | EADC_BA+0x8C | R/W | ADC Sample Module 3 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL4</b>            | EADC_BA+0x90 | R/W | ADC Sample Module 4 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL5</b>            | EADC_BA+0x94 | R/W | ADC Sample Module 5 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL6</b>            | EADC_BA+0x98 | R/W | ADC Sample Module 6 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL7</b>            | EADC_BA+0x9C | R/W | ADC Sample Module 7 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL8</b>            | EADC_BA+0xA0 | R/W | ADC Sample Module 8 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL9</b>            | EADC_BA+0xA4 | R/W | ADC Sample Module 9 Control Register            | 0x0000_0000 |
| <b>EADC_SCTL10</b>           | EADC_BA+0xA8 | R/W | ADC Sample Module 10 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL11</b>           | EADC_BA+0xAC | R/W | ADC Sample Module 11 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL12</b>           | EADC_BA+0xB0 | R/W | ADC Sample Module 12 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL13</b>           | EADC_BA+0xB4 | R/W | ADC Sample Module 13 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL14</b>           | EADC_BA+0xB8 | R/W | ADC Sample Module 14 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL15</b>           | EADC_BA+0xBC | R/W | ADC Sample Module 15 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL16</b>           | EADC_BA+0xC0 | R/W | ADC Sample Module 16 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL17</b>           | EADC_BA+0xC4 | R/W | ADC Sample Module 17 Control Register           | 0x0000_0000 |
| <b>EADC_SCTL18</b>           | EADC_BA+0xC8 | R/W | ADC Sample Module 18 Control Register           | 0x0000_0000 |
| <b>EADC_INTSRC0</b>          | EADC_BA+0xD0 | R/W | ADC interrupt 0 Source Enable Control Register. | 0x0000_0000 |
| <b>EADC_INTSRC1</b>          | EADC_BA+0xD4 | R/W | ADC interrupt 1 Source Enable Control Register. | 0x0000_0000 |
| <b>EADC_INTSRC2</b>          | EADC_BA+0xD8 | R/W | ADC interrupt 2 Source Enable Control Register. | 0x0000_0000 |
| <b>EADC_INTSRC3</b>          | EADC_BA+0xDC | R/W | ADC interrupt 3 Source Enable Control Register. | 0x0000_0000 |
| <b>EADC_CMP0</b>             | EADC_BA+0xE0 | R/W | ADC Result Compare Register 0                   | 0x0000_0000 |
| <b>EADC_CMP1</b>             | EADC_BA+0xE4 | R/W | ADC Result Compare Register 1                   | 0x0000_0000 |
| <b>EADC_CMP2</b>             | EADC_BA+0xE8 | R/W | ADC Result Compare Register 2                   | 0x0000_0000 |
| <b>EADC_CMP3</b>             | EADC_BA+0xEC | R/W | ADC Result Compare Register 3                   | 0x0000_0000 |
| <b>EADC_STATUS0</b>          | EADC_BA+0xF0 | R   | ADC Status Register 0                           | 0x0000_0000 |
| <b>EADC_STATUS1</b>          | EADC_BA+0xF4 | R   | ADC Status Register 1                           | 0x0000_0000 |
| <b>EADC_STATUS2</b>          | EADC_BA+0xF8 | R/W | ADC Status Register 2                           | 0x0000_0000 |

| Register                     | Offset        | R/W | Description                                    | Reset Value |
|------------------------------|---------------|-----|------------------------------------------------|-------------|
| <b>EADC Base Address:</b>    |               |     |                                                |             |
| <b>EADC_BA = 0x4004_3000</b> |               |     |                                                |             |
| <b>EADC_STATUS3</b>          | EADC_BA+0xFC  | R   | ADC Status Register 3                          | 0x0000_001F |
| <b>EADC_DDATA0</b>           | EADC_BA+0x100 | R   | ADC Double Data Register 0 for Sample Module 0 | 0x0000_0000 |
| <b>EADC_DDAT1</b>            | EADC_BA+0x104 | R   | ADC Double Data Register 1 for Sample Module 1 | 0x0000_0000 |
| <b>EADC_DDAT2</b>            | EADC_BA+0x108 | R   | ADC Double Data Register 2 for Sample Module 2 | 0x0000_0000 |
| <b>EADC_DDAT3</b>            | EADC_BA+0x10C | R   | ADC Double Data Register 3 for Sample Module 3 | 0x0000_0000 |
| <b>EADC_PWRM</b>             | EADC_BA+0x110 | R/W | ADC Power Management Register                  | 0x0006_E012 |
| <b>EADC_CALCTL</b>           | EADC_BA+0x114 | R/W | ADC Calibration Control Register               | 0x0000_0008 |
| <b>EADC_CALDWRD</b>          | EADC_BA+0x118 | R/W | ADC Calibration Load Word Register             | 0x0000_00XX |

### 6.37.7 Register Description

#### ADC Data Registers (EADC\_DAT0~ EADC\_DAT18)

| Register   | Offset       | R/W | Description                               | Reset Value |
|------------|--------------|-----|-------------------------------------------|-------------|
| EADC_DAT0  | 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 |

|          |    |    |    |    |    |       |    |
|----------|----|----|----|----|----|-------|----|
| 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       | <p><b>Valid Flag</b><br/>           This bit is set to 1 when corresponding sample module channel analog input conversion is 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.</p>                                                                                                                                                      |
| [16]    | OV          | <p><b>Overrun Flag</b><br/>           If converted data in RESULT[11:0] has not been read before new conversion result is loaded to 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/> <b>Note:</b> It is cleared by hardware after EADC_DAT register is read.</p>                                                                                             |
| [15:0]  | RESULT      | <p><b>ADC Conversion Result</b><br/>           This field contains 12 bits conversion result.<br/>           When DMOF (EADC_CTL[9]) is set to 0, 12-bit ADC conversion result with unsigned format will be filled in RESULT[11:0] and zero will be filled in RESULT[15:12].<br/>           When DMOF (EADC_CTL[9]) set to 1, 12-bit ADC conversion result with 2'complement format will be filled in RESULT[11:0] and signed bits to will be filled in RESULT[15:12].</p> |

ADC PDMA Current Transfer Data Register (EADC\_CURDAT)

| Register    | Offset       | R/W | Description                             |  |  |  | Reset Value |
|-------------|--------------|-----|-----------------------------------------|--|--|--|-------------|
| EADC_CURDAT | EADC_BA+0x4C | R   | ADC PDMA Current Transfer Data Register |  |  |  | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                       |
| [17:0]  | CURDAT      | <b>ADC PDMA Current Transfer Data (Read Only)</b><br>This register is a shadow register of EADC_DATn (n=0~18) for PDMA support. |

**ADC Control Register (EADC\_CTL)**

| Register | Offset       | R/W | Description          |  |  |  | Reset Value |
|----------|--------------|-----|----------------------|--|--|--|-------------|
| EADC_CTL | EADC_BA+0x50 | R/W | ADC Control Register |  |  |  | 0x0000_00C0 |

|          |    |         |         |         |          |        |        |
|----------|----|---------|---------|---------|----------|--------|--------|
| 31       | 30 | 29      | 28      | 27      | 26       | 25     | 24     |
| Reserved |    |         |         |         |          |        |        |
| 23       | 22 | 21      | 20      | 19      | 18       | 17     | 16     |
| Reserved |    |         |         |         |          |        |        |
| 15       | 14 | 13      | 12      | 11      | 10       | 9      | 8      |
| Reserved |    |         |         | PDMAEN  | Reserved | DMOF   | DIFFEN |
| 7        | 6  | 5       | 4       | 3       | 2        | 1      | 0      |
| RESSEL   |    | ADCIEN3 | ADCIEN2 | ADCIEN1 | ADCIEN0  | ADCRST | ADCEN  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [11]    | PDMAEN      | <p><b>PDMA Transfer Enable Bit</b><br/> When ADC conversion is completed, the converted data is loaded into EADC_DATn (n: 0 ~ 18) register, user can enable this bit to generate a PDMA data transfer request.<br/> 0 = PDMA data transfer Disabled.<br/> 1 = PDMA data transfer Enabled.<br/> <b>Note:</b> When set this bit field to 1, user must set ADCIENn (EADC_CTL[5:2], n=0~3) = 0 to disable interrupt.</p>                  |
| [10]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [9]     | DMOF        | <p><b>ADC Differential Input Mode Output Format</b><br/> 0 = ADC conversion result will be filled in RESULT (EADC_DATn[15:0], where n= 0 ~18) with unsigned format.<br/> 1 = ADC conversion result will be filled in RESULT (EADC_DATn[15:0], where n= 0 ~18) with 2'complement format.</p>                                                                                                                                           |
| [8]     | DIFFEN      | <p><b>Differential Analog Input Mode Enable Bit</b><br/> 0 = Single-end analog input mode.<br/> 1 = Differential analog input mode.</p>                                                                                                                                                                                                                                                                                               |
| [7:6]   | RESSEL      | <p><b>Resolution Selection</b><br/> 00 = 6-bit ADC result will be put at RESULT (EADC_DATn[5:0]).<br/> 01 = 8-bit ADC result will be put at RESULT (EADC_DATn[7:0]).<br/> 10 = 10-bit ADC result will be put at RESULT (EADC_DATn[9:0]).<br/> 11 = 12-bit ADC result will be put at RESULT (EADC_DATn[11:0]).</p>                                                                                                                     |
| [5]     | ADCIEN3     | <p><b>Specific Sample Module ADC ADINT3 Interrupt Enable Bit</b><br/> The ADC converter generates a conversion end ADIF3 (EADC_STATUS2[3]) upon the end of specific sample module ADC conversion. If ADCIEN3 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.</p> |

| Bits | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4]  | ADCIEN2     | <p><b>Specific Sample Module ADC ADINT2 Interrupt Enable Bit</b></p> <p>The ADC converter generates a conversion end ADIF2 (EADC_STATUS2[2]) upon the end of specific sample module ADC conversion. If ADCIEN2 bit is set then conversion end interrupt request ADINT2 is generated.</p> <p>0 = Specific sample module ADC ADINT2 interrupt function Disabled.<br/>1 = Specific sample module ADC ADINT2 interrupt function Enabled.</p> |
| [3]  | ADCIEN1     | <p><b>Specific Sample Module ADC ADINT1 Interrupt Enable Bit</b></p> <p>The ADC converter generates a conversion end ADIF1 (EADC_STATUS2[1]) upon the end of specific sample module ADC conversion. If ADCIEN1 bit is set then conversion end interrupt request ADINT1 is generated.</p> <p>0 = Specific sample module ADC ADINT1 interrupt function Disabled.<br/>1 = Specific sample module ADC ADINT1 interrupt function Enabled.</p> |
| [2]  | ADCIENO     | <p><b>Specific Sample Module ADC ADINT0 Interrupt Enable Bit</b></p> <p>The ADC converter generates a conversion end ADIF0 (EADC_STATUS2[0]) upon the end of specific sample module ADC conversion. If ADCIENO bit is set then conversion end interrupt request ADINT0 is generated.</p> <p>0 = Specific sample module ADC ADINT0 interrupt function Disabled.<br/>1 = Specific sample module ADC ADINT0 interrupt function Enabled.</p> |
| [1]  | ADCRST      | <p><b>ADC Converter Control Circuits Reset</b></p> <p>0 = No effect.<br/>1 = Cause ADC control circuits reset to initial state, but not change the ADC registers value.</p> <p><b>Note:</b> ADCRST bit remains 1 during ADC reset, when ADC reset end, the ADCRST bit is automatically cleared to 0.</p>                                                                                                                                 |
| [0]  | ADCEN       | <p><b>ADC Converter Enable Bit</b></p> <p>0 = Disabled EADC.<br/>1 = Enabled EADC.</p> <p><b>Note:</b> Before starting ADC conversion function, this bit should be set to 1. Clear it to 0 to disable ADC converter analog circuit power consumption.</p>                                                                                                                                                                                |

**ADC Sample Module Software Start Register (EADC\_SWTRG)**

| Register   | Offset       | R/W | Description                               |  |  |  | Reset Value |
|------------|--------------|-----|-------------------------------------------|--|--|--|-------------|
| EADC_SWTRG | EADC_BA+0x54 | W   | ADC Sample Module Software Start Register |  |  |  | 0x0000_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]  | SWTRG       | <p><b>ADC Sample Module 0~18 Software Force to Start ADC Conversion</b><br/>           0 = No effect.<br/>           1 = Cause an ADC conversion when the priority is given to sample module.</p> <p><b>Note:</b> After writing this register to start ADC conversion, the EADC_PENDSTS register will show which sample module will conversion. If user want to disable the conversion of the sample module, user can write EADC_PENDSTS register to clear it.</p> |

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 |  |  |  | 0x0000_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        | <p><b>ADC Sample Module 0~18 Start of Conversion Pending Flag</b></p> <p>Read Operation:</p> <p>0 = There is no pending conversion for sample module.<br/>1 = Sample module ADC start of conversion is pending.</p> <p>Write Operation:</p> <p>1 = Clear pending flag &amp; cancel the conversion for sample module.</p> <p><b>Note:</b> This bit remains 1 during pending state, when the respective ADC conversion is end, the STPF<sub>n</sub> (n=0~18) bit is automatically cleared to 0.</p> |

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 | 0x0000_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       | <p><b>ADC SAMPLE0~18 Overrun Flag</b><br/>           0 = No sample module event overrun.<br/>           1 = Indicates a new sample module event is generated while an old one event is pending.<br/> <b>Note:</b> This bit is cleared by writing 1 to it.</p> |

ADC Sample Module 0~3 Control Registers (EADC\_SCTL0~EADC\_SCTL3)

| Register   | Offset       | R/W | Description                          |  |  |  | Reset Value |
|------------|--------------|-----|--------------------------------------|--|--|--|-------------|
| EADC_SCTL0 | 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 |
| EADC_SCTL3 | EADC_BA+0x8C | R/W | ADC Sample Module 3 Control Register |  |  |  | 0x0000_0000 |

|           |        |          |        |       |    |    |    |
|-----------|--------|----------|--------|-------|----|----|----|
| 31        | 30     | 29       | 28     | 27    | 26 | 25 | 24 |
| EXTSMPT   |        |          |        |       |    |    |    |
| 23        | 22     | 21       | 20     | 19    | 18 | 17 | 16 |
| DBMEN     | 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] | <b>EXTSMPT</b>  | <b>ADC Sampling Time Extend</b><br>When ADC converting at high conversion rate, the sampling time of analog input voltage may not enough if input channel loading is heavy, user can extend ADC sampling time after trigger source is coming to get enough sampling time.<br>The range of start delay time is from 0~255 ADC clock. |
| [23]    | <b>DBMEN</b>    | <b>Double Buffer Mode Enable Bit</b><br>0 = Sample has one sample result register (default).<br>1 = Sample has two sample result registers.                                                                                                                                                                                         |
| [22]    | <b>INTPOS</b>   | <b>Interrupt Flag Position Select</b><br>0 = Set ADIFn (EADC_STATUS2[n], n=0~3) at ADC end of conversion.<br>1 = Set ADIFn (EADC_STATUS2[n], n=0~3) at ADC start of conversion.                                                                                                                                                     |
| [21]    | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                           |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [20:16] | <b>TRGSEL</b><br><b>ADC Sample Module Start of Conversion Trigger Source Selection</b><br>0H = Disable trigger.<br>1H = External trigger from EADC0_ST pin input.<br>2H = ADC ADINT0 interrupt EOC (End of conversion) pulse trigger.<br>3H = ADC ADINT1 interrupt EOC (End of conversion) pulse trigger.<br>4H = Timer0 overflow pulse trigger.<br>5H = Timer1 overflow pulse trigger.<br>6H = Timer2 overflow pulse trigger.<br>7H = Timer3 overflow pulse trigger.<br>8H = EPWM0TG0.<br>9H = EPWM0TG1.<br>AH = EPWM0TG2.<br>BH = EPWM0TG3.<br>CH = EPWM0TG4.<br>DH = EPWM0TG5.<br>EH = EPWM1TG0.<br>FH = EPWM1TG1.<br>10H = EPWM1TG2.<br>11H = EPWM1TG3.<br>12H = EPWM1TG4.<br>13H = EPWM1TG5.<br>14H = BPWM0TG.<br>15H = BPWM1TG.<br>other = Reserved. |
| [15:8]  | <b>TRGDLYCNT</b><br><b>ADC Sample Module Start of Conversion Trigger Delay Time</b><br>Trigger delay time = TRGDLYCNT x ADC_CLK period x n (n=1,2,4,16 from TRGDLYDIV setting).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [7:6]   | <b>TRGDLYDIV</b><br><b>ADC Sample Module Start of Conversion Trigger Delay Clock Divider Selection</b><br>Trigger delay clock frequency:<br>00 = ADC_CLK/1.<br>01 = ADC_CLK/2.<br>10 = ADC_CLK/4.<br>11 = ADC_CLK/16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [5]     | <b>EXTFEN</b><br><b>ADC External Trigger Falling Edge Enable Bit</b><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]     | <b>EXTREN</b><br><b>ADC External Trigger Rising Edge Enable Bit</b><br>0 = Rising edge Disabled when ADC selects EADC0_ST as trigger source.<br>1 = Rising edge Enabled when ADC selects EADC0_ST as trigger source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:0] | <b>CHSEL</b><br><b>ADC Sample Module Channel Selection</b><br>00H = EADC_CH0 (slow channel).<br>01H = EADC_CH1 (slow channel).<br>02H = EADC_CH2 (slow channel).<br>03H = EADC_CH3 (slow channel).<br>04H = EADC_CH4 (slow channel).<br>05H = EADC_CH5 (slow channel).<br>06H = EADC_CH6 (slow channel).<br>07H = EADC_CH7 (slow channel).<br>08H = EADC_CH8 (slow channel).<br>09H = EADC_CH9 (slow channel).<br>0AH = EADC_CH10 (fast channel).<br>0BH = EADC_CH11 (fast channel).<br>0CH = EADC_CH12 (fast channel).<br>0DH = EADC_CH13 (fast channel).<br>0EH = EADC_CH14 (fast channel).<br>0FH = EADC_CH15 (fast channel). |

**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     | <b>ADC Sampling Time Extend</b><br>When ADC converting at high conversion rate, the sampling time of analog input voltage may not enough if input channel loading is heavy, SW can extend ADC sampling time after trigger source is coming to get enough sampling time.<br>The range of start delay time is from 0~255 ADC clock. |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                         |
| [22]    | INTPOS      | <b>Interrupt Flag Position Select</b><br>0 = Set ADIFn (EADC_STATUS2[n], n=0~3) at ADC end of conversion.<br>1 = Set ADIFn (EADC_STATUS2[n], n=0~3) at ADC start of conversion.                                                                                                                                                   |
| [21]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                         |

| Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [20:16] | <b>TRGSEL</b><br><b>ADC Sample Module Start of Conversion Trigger Source Selection</b><br>0H = Disable trigger.<br>1H = External trigger from EADC0_ST pin input.<br>2H = ADC ADINT0 interrupt EOC pulse trigger.<br>3H = ADC ADINT1 interrupt EOC pulse trigger.<br>4H = Timer0 overflow pulse trigger.<br>5H = Timer1 overflow pulse trigger.<br>6H = Timer2 overflow pulse trigger.<br>7H = Timer3 overflow pulse trigger.<br>8H = PWM0TG0.<br>9H = PWM0TG1.<br>AH = PWM0TG2.<br>BH = PWM0TG3.<br>CH = PWM0TG4.<br>DH = PWM0TG5.<br>EH = PWM1TG0.<br>FH = PWM1TG1.<br>10H = PWM1TG2.<br>11H = PWM1TG3.<br>12H = EPWM1TG4.<br>13H = PWM1TG5.<br>14H = BPWM0TG.<br>15H = BPWM1TG.<br>other = Reserved. |
| [15:8]  | <b>TRGDLYCNT</b><br><b>ADC Sample Module Start of Conversion Trigger Delay Time</b><br>Trigger delay time = TRGDLYCNT x ADC_CLK period x n (n=1,2,4,16 from TRGDLYDIV setting).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [7:6]   | <b>TRGDLYDIV</b><br><b>ADC Sample Module Start of Conversion Trigger Delay Clock Divider Selection</b><br>Trigger delay clock frequency:<br>00 = ADC_CLK/1.<br>01 = ADC_CLK/2.<br>10 = ADC_CLK/4.<br>11 = ADC_CLK/16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [5]     | <b>EXTFEN</b><br><b>ADC External Trigger Falling Edge Enable Bit</b><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]     | <b>EXTREN</b><br><b>ADC External Trigger Rising Edge Enable Bit</b><br>0 = Rising edge Disabled when ADC selects EADC0_ST as trigger source.<br>1 = Rising edge Enabled when ADC selects EADC0_ST as trigger source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:0] | <b>CHSEL</b><br><b>ADC Sample Module Channel Selection</b><br>00H = EADC_CH0 (slow channel).<br>01H = EADC_CH1 (slow channel).<br>02H = EADC_CH2 (slow channel).<br>03H = EADC_CH3 (slow channel).<br>04H = EADC_CH4 (slow channel).<br>05H = EADC_CH5 (slow channel).<br>06H = EADC_CH6 (slow channel).<br>07H = EADC_CH7 (slow channel).<br>08H = EADC_CH8 (slow channel).<br>09H = EADC_CH9 (slow channel).<br>0AH = EADC_CH10 (fast channel).<br>0BH = EADC_CH11 (fast channel).<br>0CH = EADC_CH12 (fast channel).<br>0DH = EADC_CH13 (fast channel).<br>0EH = EADC_CH14 (fast channel).<br>0FH = EADC_CH15 (fast channel). |

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

|          |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|
| 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] | <b>EXTSMPT</b>  | <b>ADC Sampling Time Extend</b><br>When ADC converting at high conversion rate, the sampling time of analog input voltage may not enough if input channel loading is heavy, SW can extend ADC sampling time after trigger source is coming to get enough sampling time.<br>The range of start delay time is from 0~255 ADC clock. |
| [23:0]  | <b>Reserved</b> | 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 | ADC interrupt 0 Source Enable Control Register. |  |  | 0x0000_0000 |
| EADC_INTSRC1 | EADC_BA+0xD4 | R/W | ADC interrupt 1 Source Enable Control Register. |  |  | 0x0000_0000 |
| EADC_INTSRC2 | EADC_BA+0xD8 | R/W | ADC interrupt 2 Source Enable Control Register. |  |  | 0x0000_0000 |
| EADC_INTSRC3 | EADC_BA+0xDC | R/W | ADC interrupt 3 Source Enable Control Register. |  |  | 0x0000_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 |                                                                                                                                     |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| [18] | SPLIE18     | <b>Sample Module 18 Interrupt Enable Bit</b><br>0 = Sample Module 18 interrupt Disabled.<br>1 = Sample Module 18 interrupt Enabled. |
| [17] | SPLIE17     | <b>Sample Module 17 Interrupt Enable Bit</b><br>0 = Sample Module 17 interrupt Disabled.<br>1 = Sample Module 17 interrupt Enabled. |
| [16] | SPLIE16     | <b>Sample Module 16 Interrupt Enable Bit</b><br>0 = Sample Module 16 interrupt Disabled.<br>1 = Sample Module 16 interrupt Enabled. |
| [15] | SPLIE15     | <b>Sample Module 15 Interrupt Enable Bit</b><br>0 = Sample Module 15 interrupt Disabled.<br>1 = Sample Module 15 interrupt Enabled. |
| [14] | SPLIE14     | <b>Sample Module 14 Interrupt Enable Bit</b><br>0 = Sample Module 14 interrupt Disabled.<br>1 = Sample Module 14 interrupt Enabled. |
| [13] | SPLIE13     | <b>Sample Module 13 Interrupt Enable Bit</b><br>0 = Sample Module 13 interrupt Disabled.<br>1 = Sample Module 13 interrupt Enabled. |
| [12] | SPLIE12     | <b>Sample Module 12 Interrupt Enable Bit</b><br>0 = Sample Module 12 interrupt Disabled.<br>1 = Sample Module 12 interrupt Enabled. |

| Bits | Description |                                                                                                                                     |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| [11] | SPLIE11     | <b>Sample Module 11 Interrupt Enable Bit</b><br>0 = Sample Module 11 interrupt Disabled.<br>1 = Sample Module 11 interrupt Enabled. |
| [10] | SPLIE10     | <b>Sample Module 10 Interrupt Enable Bit</b><br>0 = Sample Module 10 interrupt Disabled.<br>1 = Sample Module 10 interrupt Enabled. |
| [9]  | SPLIE9      | <b>Sample Module 9 Interrupt Enable Bit</b><br>0 = Sample Module 9 interrupt Disabled.<br>1 = Sample Module 9 interrupt Enabled.    |
| [8]  | SPLIE8      | <b>Sample Module 8 Interrupt Enable Bit</b><br>0 = Sample Module 8 interrupt Disabled.<br>1 = Sample Module 8 interrupt Enabled.    |
| [7]  | SPLIE7      | <b>Sample Module 7 Interrupt Enable Bit</b><br>0 = Sample Module 7 interrupt Disabled.<br>1 = Sample Module 7 interrupt Enabled.    |
| [6]  | SPLIE6      | <b>Sample Module 6 Interrupt Enable Bit</b><br>0 = Sample Module 6 interrupt Disabled.<br>1 = Sample Module 6 interrupt Enabled.    |
| [5]  | SPLIE5      | <b>Sample Module 5 Interrupt Enable Bit</b><br>0 = Sample Module 5 interrupt Disabled.<br>1 = Sample Module 5 interrupt Enabled.    |
| [4]  | SPLIE4      | <b>Sample Module 4 Interrupt Enable Bit</b><br>0 = Sample Module 4 interrupt Disabled.<br>1 = Sample Module 4 interrupt Enabled.    |
| [3]  | SPLIE3      | <b>Sample Module 3 Interrupt Enable Bit</b><br>0 = Sample Module 3 interrupt Disabled.<br>1 = Sample Module 3 interrupt Enabled.    |
| [2]  | SPLIE2      | <b>Sample Module 2 Interrupt Enable Bit</b><br>0 = Sample Module 2 interrupt Disabled.<br>1 = Sample Module 2 interrupt Enabled.    |
| [1]  | SPLIE1      | <b>Sample Module 1 Interrupt Enable Bit</b><br>0 = Sample Module 1 interrupt Disabled.<br>1 = Sample Module 1 interrupt Enabled.    |
| [0]  | SPLIE0      | <b>Sample Module 0 Interrupt Enable Bit</b><br>0 = Sample Module 0 interrupt Disabled.<br>1 = Sample Module 0 interrupt Enabled.    |

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

|          |          |    |    |          |         |          |    |
|----------|----------|----|----|----------|---------|----------|----|
| 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 |    |    | CMPPMCNT |         |          |    |
| 7        | 6        | 5  | 4  | 3        | 2       | 1        | 0  |
| CMPSPL   |          |    |    | CMPCOND  | ADCMPIE | ADCMPPEN |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [27:16] | CMPDAT      | <b>Comparison Data</b><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      | <b>Compare Window Mode Enable Bit</b><br>0 = ADCMPF0 (EADC_STATUS2[4]) will be set when EADC_CMP0 compared condition matched. ADCMPF2 (EADC_STATUS2[6]) will be set when EADC_CMP2 compared condition matched<br>1 = ADCMPF0 (EADC_STATUS2[4]) will be set when both EADC_CMP0 and EADC_CMP1 compared condition matched. ADCMPF2 (EADC_STATUS2[6]) will be set when both EADC_CMP2 and EADC_CMP3 compared condition matched.<br><b>Note:</b> This bit is only present in EADC_CMP0 and EADC_CMP2 register. |
| [14:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [11:8]  | CMPPMCNT    | <b>Compare Match Count</b><br>When the specified ADC sample module analog conversion result matches the compare condition defined by CMPCOND (EADC_CMPPn[2], n=0~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 (CMPPMCNT +1), the ADCMPFn (EADC_STATUS2[7:4], n=0~3) will be set.                                                          |

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:3] | <p><b>Compare Sample Module Selection</b></p> <p>00000 = Sample Module 0 conversion result EADC_DAT0 is selected to be compared.</p> <p>00001 = Sample Module 1 conversion result EADC_DAT1 is selected to be compared.</p> <p>00010 = Sample Module 2 conversion result EADC_DAT2 is selected to be compared.</p> <p>00011 = Sample Module 3 conversion result EADC_DAT3 is selected to be compared.</p> <p>00100 = Sample Module 4 conversion result EADC_DAT4 is selected to be compared.</p> <p>00101 = Sample Module 5 conversion result EADC_DAT5 is selected to be compared.</p> <p>00110 = Sample Module 6 conversion result EADC_DAT6 is selected to be compared.</p> <p>00111 = Sample Module 7 conversion result EADC_DAT7 is selected to be compared.</p> <p>01000 = Sample Module 8 conversion result EADC_DAT8 is selected to be compared.</p> <p>01001 = Sample Module 9 conversion result EADC_DAT9 is selected to be compared.</p> <p>01010 = Sample Module 10 conversion result EADC_DAT10 is selected to be compared.</p> <p>01011 = Sample Module 11 conversion result EADC_DAT11 is selected to be compared.</p> <p>01100 = Sample Module 12 conversion result EADC_DAT12 is selected to be compared.</p> <p>01101 = Sample Module 13 conversion result EADC_DAT13 is selected to be compared.</p> <p>01110 = Sample Module 14 conversion result EADC_DAT14 is selected to be compared.</p> <p>01111 = Sample Module 15 conversion result EADC_DAT15 is selected to be compared.</p> <p>10000 = Sample Module 16 conversion result EADC_DAT16 is selected to be compared.</p> <p>10001 = Sample Module 17 conversion result EADC_DAT17 is selected to be compared.</p> <p>10010 = Sample Module 18 conversion result EADC_DAT18 is selected to be compared.</p> |
| [2]   | <p><b>Compare Condition</b></p> <p>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.</p> <p>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.</p> <p><b>Note:</b> When the internal counter reaches the value to (CMPMCNT (EADC_CMPn[11:8], n=0~3) +1), the CMPF bit will be set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [1]   | <p><b>ADC Result Compare Interrupt Enable Bit</b></p> <p>0 = Compare function interrupt Disabled.</p> <p>1 = Compare function interrupt Enabled.</p> <p>If the compare function is enabled and the compare condition matches the setting of CMPCOND (EADC_CMPn[2], n=0~3) and CMPMCNT (EADC_CMPn[11:8], n=0~3), ADCMPFn (EADC_STATUS2[7:4], n=0~3) will be asserted, in the meanwhile, if ADCMPIE is set to 1, a compare interrupt request is generated.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]   | <p><b>ADC Result Compare Enable Bit</b></p> <p>0 = Compare Disabled.</p> <p>1 = Compare Enabled.</p> <p>Set this bit to 1 to enable compare CMPDAT (EADC_CMPn[27:16], n=0~3) with specified sample module conversion result when converted data is loaded into EADC_DAT register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

ADC Status Register 0 (EADC\_STATUS0)

| 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          | <b>EADC_DAT0~15 Overrun Flag</b><br>It is a mirror to OV bit in sample module ADC result data register EADC_DATn. (n=0~18).       |
| [15:0]  | VALID       | <b>EADC_DAT0~15 Data Valid Flag</b><br>It is a mirror of VALID bit in sample module ADC result data register EADC_DATn. (n=0~18). |

**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          | <b>EADC_DAT16~18 Overrun Flag</b><br>It is a mirror to OV bit in sample module ADC result data register EADC_DATn. (n=0~18).       |
| [15:3]  | Reserved    | Reserved.                                                                                                                          |
| [2:0]   | VALID       | <b>EADC_DAT16~18 Data Valid Flag</b><br>It is a mirror of VALID bit in sample module ADC result data register EADC_DATn. (n=0~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 |  |  | 0x0000_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       |
| ADCMPO3 | ADCMPO2 | ADCMPO1  | ADCMPO0 | ADOVIF3 | ADOVIF2 | ADOVIF1 | ADOVIF0 |
| 7       | 6       | 5        | 4       | 3       | 2       | 1       | 0       |
| ADCMPF3 | ADCMPF2 | ADCMPF1  | ADCMPF0 | ADIF3   | ADIF2   | ADIF1   | ADIF0   |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                    |
| [27]    | AOV         | <p><b>for All Sample Module ADC Result Data Register Overrun Flags Check (Read Only)</b><br/>n=0~18.</p> <p>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.</p> <p><b>Note:</b> This bit will keep 1 when any OVn Flag is equal to 1.</p>                 |
| [26]    | AVALID      | <p><b>for All Sample Module ADC Result Data Register EADC_DAT Data Valid Flag Check (Read Only)</b><br/>n=0~18.</p> <p>0 = None of sample module data register valid flag VALIDn (EADC_DATn[17]) is set to 1.<br/>1 = Any one of sample module data register valid flag VALIDn (EADC_DATn[17]) is set to 1.</p> <p><b>Note:</b> This bit will keep 1 when any VALIDn Flag is equal to 1.</p> |
| [25]    | STOVF       | <p><b>for All ADC Sample Module Start of Conversion Overrun Flags Check (Read Only)</b><br/>n=0~18.</p> <p>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.</p> <p><b>Note:</b> This bit will keep 1 when any SPOVFn Flag is equal to 1.</p>                         |
| [24]    | ADOVIF      | <p><b>All ADC Interrupt Flag Overrun Bits Check (Read Only)</b><br/>n=0~3.</p> <p>0 = None of ADINT interrupt flag ADOVIFn (EADC_STATUS2[11:8]) is overwritten to 1.<br/>1 = Any one of ADINT interrupt flag ADOVIFn (EADC_STATUS2[11:8]) is overwritten to 1.</p> <p><b>Note:</b> This bit will keep 1 when any ADOVIFn Flag is equal to 1.</p>                                             |
| [23]    | BUSY        | <p><b>Busy/Idle (Read Only)</b></p> <p>0 = EADC is in idle state.<br/>1 = EADC is busy at conversion.</p>                                                                                                                                                                                                                                                                                    |

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [22:21] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [20:16] | <b>CHANNEL</b>  | <p><b>Current Conversion Channel (Read Only)</b></p> <p>This field reflects ADC current conversion channel when BUSY=1.</p> <p>It is read only.</p> <p>00H = EADC_CH0.<br/>     01H = EADC_CH1.<br/>     02H = EADC_CH2.<br/>     03H = EADC_CH3.<br/>     04H = EADC_CH4.<br/>     05H = EADC_CH5.<br/>     06H = EADC_CH6.<br/>     07H = EADC_CH7.<br/>     08H = EADC_CH8.<br/>     09H = EADC_CH9.<br/>     0AH = EADC_CH10.<br/>     0BH = EADC_CH11.<br/>     0CH = EADC_CH12.<br/>     0DH = EADC_CH13.<br/>     0EH = EADC_CH14.<br/>     0FH = EADC_CH15.<br/>     10H = <math>V_{BG}</math> (default).<br/>     11H = <math>V_{TEMP}</math>.<br/>     12H = <math>V_{DD}/4</math>.</p> |
| [15]    | <b>ADCMPO3</b>  | <p><b>ADC Compare 3 Output Status (Read Only)</b></p> <p>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.</p> <p>0 = Conversion result in EADC_DAT less than CMPDAT3 setting.<br/>     1 = Conversion result in EADC_DAT great than or equal CMPDAT3 setting.</p>                                                                                                                                                                                                                                                                              |
| [14]    | <b>ADCMPO2</b>  | <p><b>ADC Compare 2 Output Status (Read Only)</b></p> <p>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.</p> <p>0 = Conversion result in EADC_DAT less than CMPDAT2 setting.<br/>     1 = Conversion result in EADC_DAT great than or equal CMPDAT2 setting.</p>                                                                                                                                                                                                                                                                              |
| [13]    | <b>ADCMPO1</b>  | <p><b>ADC Compare 1 Output Status (Read Only)</b></p> <p>The 12 bits compare1 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.</p> <p>0 = Conversion result in EADC_DAT less than CMPDAT1 setting.<br/>     1 = Conversion result in EADC_DAT great than or equal CMPDAT1 setting.</p>                                                                                                                                                                                                                                                                              |
| [12]    | <b>ADCMPO0</b>  | <p><b>ADC Compare 0 Output Status (Read Only)</b></p> <p>The 12 bits compare0 data CMPDAT0 (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.</p> <p>0 = Conversion result in EADC_DAT less than CMPDAT0 setting.<br/>     1 = Conversion result in EADC_DAT great than or equal CMPDAT0 setting.</p>                                                                                                                                                                                                                                                                              |

| Bits | Description |                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11] | ADOVIF3     | <p><b>ADC ADINT3 Interrupt Flag Overrun</b><br/>           0 = ADINT3 interrupt flag is not overwritten to 1.<br/>           1 = ADINT3 interrupt flag is overwritten to 1.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p>                                                                                                                                                                     |
| [10] | ADOVIF2     | <p><b>ADC ADINT2 Interrupt Flag Overrun</b><br/>           0 = ADINT2 interrupt flag is not overwritten to 1.<br/>           1 = ADINT2 interrupt flag is s overwritten to 1.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p>                                                                                                                                                                   |
| [9]  | ADOVIF1     | <p><b>ADC ADINT1 Interrupt Flag Overrun</b><br/>           0 = ADINT1 interrupt flag is not overwritten to 1.<br/>           1 = ADINT1 interrupt flag is overwritten to 1.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p>                                                                                                                                                                     |
| [8]  | ADOVIF0     | <p><b>ADC ADINT0 Interrupt Flag Overrun</b><br/>           0 = ADINT0 interrupt flag is not overwritten to 1.<br/>           1 = ADINT0 interrupt flag is overwritten to 1.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p>                                                                                                                                                                     |
| [7]  | ADCMPF3     | <p><b>ADC Compare 3 Flag</b><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.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p> |
| [6]  | ADCMPF2     | <p><b>ADC Compare 2 Flag</b><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.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p> |
| [5]  | ADCMPF1     | <p><b>ADC Compare 1 Flag</b><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.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p> |
| [4]  | ADCMPF0     | <p><b>ADC Compare 0 Flag</b><br/>           When the specific sample module ADC conversion result meets setting condition in EADC_CMP0 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.</p> <p><b>Note:</b> This bit is cleared by writing 1 to it.</p> |

| Bits | Description                                                                                                                                                                                                                                                                                                      |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]  | <b>ADIF3</b><br><b>ADC ADINT3 Interrupt Flag</b><br>0 = No ADINT3 interrupt pulse received.<br>1 = ADINT3 interrupt pulse has been received.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> This bit indicates whether an ADC conversion of specific sample module has been completed |
| [2]  | <b>ADIF2</b><br><b>ADC ADINT2 Interrupt Flag</b><br>0 = No ADINT2 interrupt pulse received.<br>1 = ADINT2 interrupt pulse has been received.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> This bit indicates whether an ADC conversion of specific sample module has been completed |
| [1]  | <b>ADIF1</b><br><b>ADC ADINT1 Interrupt Flag</b><br>0 = No ADINT1 interrupt pulse received.<br>1 = ADINT1 interrupt pulse has been received.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> This bit indicates whether an ADC conversion of specific sample module has been completed |
| [0]  | <b>ADIF0</b><br><b>ADC ADINT0 Interrupt Flag</b><br>0 = No ADINT0 interrupt pulse received.<br>1 = ADINT0 interrupt pulse has been received.<br><b>Note1:</b> This bit is cleared by writing 1 to it.<br><b>Note2:</b> 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 |                                                                                                                                                                                                        |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                              |
| [4:0]  | CURSPL      | <b>ADC Current Sample Module (Read Only)</b><br>This register shows the current ADC is controlled by which sample module control logic modules.<br>If the ADC is Idle, the bit filed will set to 0x1F. |

ADC Double Data Register n for Sample Module n (EADC\_DDAT0~3)

| Register   | Offset        | R/W | Description                                    |  |  | Reset Value |
|------------|---------------|-----|------------------------------------------------|--|--|-------------|
| EADC_DDAT0 | EADC_BA+0x100 | R   | ADC Double Data Register 0 for Sample Module 0 |  |  | 0x0000_0000 |
| EADC_DDAT1 | EADC_BA+0x104 | R   | ADC Double Data Register 1 for Sample Module 1 |  |  | 0x0000_0000 |
| EADC_DDAT2 | EADC_BA+0x108 | R   | ADC Double Data Register 2 for Sample Module 2 |  |  | 0x0000_0000 |
| EADC_DDAT3 | EADC_BA+0x10C | R   | ADC Double Data Register 3 for Sample Module 3 |  |  | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [17]    | VALID       | <p><b>Valid Flag</b><br/>           0 = Double data in RESULT (EADC_DDATn[15:0]) is not valid.<br/>           1 = Double data in RESULT (EADC_DDATn[15:0]) is valid.<br/>           This bit is set to 1 when corresponding sample module channel analog input conversion is completed and cleared by hardware after EADC_DDATn register is read. (n=0~3).</p>                                                                                                                         |
| [16]    | OV          | <p><b>Overrun Flag</b><br/>           0 = Data in RESULT (EADC_DATn[15:0], n=0~3) is recent conversion result.<br/>           1 = Data in RESULT (EADC_DATn[15:0], n=0~3) is overwrite.<br/>           If converted data in RESULT[15:0] has not been read before new conversion result is loaded to this register, OV is set to 1. It is cleared by hardware after EADC_DDAT register is read.</p>                                                                                    |
| [15:0]  | RESULT      | <p><b>ADC Conversion Results</b><br/>           This field contains 12 bits conversion results.<br/>           When the DMOF (EADC_CTL[9]) is set to 0, 12-bit ADC conversion result with unsigned format will be filled in RESULT [11:0] and zero will be filled in RESULT [15:12].<br/>           When DMOF (EADC_CTL[9]) is set to 1, 12-bit ADC conversion result with 2's complement format will be filled in RESULT [11:0] and signed bits will be filled in RESULT [15:12].</p> |

**ADC Power Management Register (EADC\_PWRM)**

| Register  | Offset        | R/W | Description                   |  |  |  | Reset Value |
|-----------|---------------|-----|-------------------------------|--|--|--|-------------|
| EADC_PWRM | EADC_BA+0x110 | R/W | ADC Power Management Register |  |  |  | 0x0006_E012 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [19:8]  | LDOSUT      | <b>ADC Internal LDO Start-up Time</b><br>Set this bit field to control LDO start-up time. The minimum required LDO start-up time is 20us. LDO start-up time = (1/ADC_CLK) x LDOSUT.                                                                                                                                                                                                                                                                                                                                           |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [3:2]   | PWDMOD      | <b>ADC Power-down Mode</b><br>Set this bit field to select ADC Power-down mode when system power-down.<br>00 = ADC Deep Power-down mode.<br>01 = ADC Power down.<br>10 = ADC Standby mode.<br>11 = ADC Deep Power-down mode.<br><b>Note:</b> Different PWDMOD has different power down/up sequence, in order to avoid ADC powering up with wrong sequence; user must keep PWMOD consistent each time in power down and start up.                                                                                              |
| [1]     | PWUCALEN    | <b>Power Up Calibration Function Enable Bit</b><br>0 = Calibration function Disabled at power up.<br>1 = Calibration function Enabled at power up.<br><b>Note:</b> This bit work together with CALSEL (EADC_CALCTL [3]), see the following {PWUCALEN, CALSEL } Description:<br>PWUCALEN is 0 and CALSEL is 0: No need to calibrate.<br>PWUCALEN is 0 and CALSEL is 1: No need to calibrate.<br>PWUCALEN is 1 and CALSEL is 0: Load calibration word when power up.<br>PWUCALEN is 1 and CALSEL is 1: Calibrate when power up. |
| [0]     | PWUPRDY     | <b>ADC Power-up Sequence Completed and Ready for Conversion (Read Only)</b><br>0 = ADC is not ready for conversion may be in power down state or in the progress of start up.<br>1 = ADC is ready for conversion.                                                                                                                                                                                                                                                                                                             |

**ADC Calibration Control Register (EADC\_CALCTL)**

| Register    | Offset        | R/W | Description                      |  |  |  | Reset Value |
|-------------|---------------|-----|----------------------------------|--|--|--|-------------|
| EADC_CALCTL | EADC_BA+0x114 | R/W | ADC Calibration Control Register |  |  |  | 0x0000_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        |
| Reserved |    |    |    | CALSEL | CALDONE | CALSTART | Reserved |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                         |
| [3]    | CALSEL      | <b>Select Calibration Functional Block</b><br>0 = Load calibration word when calibration functional block is active.<br>1 = Execute calibration when calibration functional block is active.                                                                                                                                                      |
| [2]    | CALDONE     | <b>Calibration Functional Block Complete (Read Only)</b><br>0 = During a calibration.<br>1 = Calibration is completed.                                                                                                                                                                                                                            |
| [1]    | CALSTART    | <b>Calibration Functional Block Start</b><br>0 = Stop calibration functional block.<br>1 = Start calibration functional block.<br><b>Note1:</b> This bit is set by SW and clear by HW after re-calibration finish.<br><b>Note2:</b> Before set CALSTART (EADC_CALCTL[1]) as 1 to start calibration again, EADCDIV (CKL_CLKDIV0[23:16]) must be 0. |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                         |

**ADC Calibration Load Word Register (EADC\_CALWORD)**

| Register    | Offset        | R/W | Description                        |  |  |  |  | Reset Value |
|-------------|---------------|-----|------------------------------------|--|--|--|--|-------------|
| EADC_CALWRD | EADC_BA+0x118 | R/W | ADC Calibration Load Word 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  |
| Reserved | CALWORD |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [6:0]  | CALWORD     | <p><b>Calibration Word Bits</b></p> <p>Write to this register with the previous calibration word before load calibration action.<br/>Read this register after calibration done.</p> <p><b>Note:</b> The calibration block contains two parts “CALIBRATION” and “LOAD CALIBRATION”; if the calibration block configure as “CALIBRATION”; then this register represent the result of calibration when calibration is completed; if configure as “LOAD CALIBRATION” ; configure this register before loading calibration action, after loading calibration complete, the loaded calibration word will apply to the ADC; while in loading calibration function the loaded value will not be equal to the original CALWORD until calibration is done.</p> |

## 6.38 Digital to Analog Converter (DAC)

### 6.38.1 Overview

The DAC module is a 12-bit, voltage output digital-to-analog converter. It can be configured to 12- or 8-bit 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 impedance and drive external loads directly without having to add an external operational amplifier.

### 6.38.2 Features

- Analog output voltage range: 0~AVDD.
- 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), V<sub>REF</sub> 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, EPWM0, EPWM1, and external trigger pin to start DAC conversion.
- Supports PDMA mode.
- Supports group mode of synchronized update capability for two DACs.

### 6.38.3 Block Diagram



Figure 6.38-1 Digital-to-Analog Converter Block Diagram

### 6.38.4 Basic Configuration

#### 6.38.4.1 DAC0 Basic Configuration

- Clock source Configuration
  - Enable DAC0 peripheral clock in DACCKEN (CLK\_APBCLK1[12]).
- Reset Configuration
  - Reset DAC0 controller in DCRST (SYS\_IPRST2[12]).
- Pin configuration

| Group | Pin Name | GPIO | MFP |
|-------|----------|------|-----|
|-------|----------|------|-----|

|      |          |       |       |
|------|----------|-------|-------|
| DAC0 | DAC0_OUT | PB.12 | MFP1  |
|      | DAC0_ST  | PA.10 | MFP14 |
|      |          | PA.0  | MFP15 |

#### 6.38.4.2 DAC1 Basic Configuration

- Clock source Configuration
  - Enable DAC1 peripheral clock in DACCKEN (CLK\_APBCLK1[12]).
- Reset Configuration
  - Reset DAC1 controller in DCRST (SYS\_IPRST2[12]).
- Pin configuration

| Group | Pin Name | GPIO  | MFP   |
|-------|----------|-------|-------|
| DAC1  | DAC1_OUT | PB.13 | MFP1  |
|       | DAC1_ST  | PA.11 | MFP14 |
|       |          | PA.1  | MFP15 |

### 6.38.5 Functional Description

#### 6.38.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 impedance 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.38.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 ( $V_{REF}$ ) or internal reference voltage generator (INT\_VREF).

#### 6.38.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.38-2 Data Holding Register Format

#### 6.38.5.4 DAC Conversion

Any data transfer to the DAC channel is performed by loading the data into DACn\_DAT register. Figure 6.38-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.38-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 8us when 12-bit input code transition from lowest code (0x000) to highest code (0xFFFF). Two adjacent codes conversion settling time is 1us. 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 80MHz and DAC conversion settling time is 8us, the selected SETTLET value must be greater than 0x280. 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 n=0,1.



Figure 6.38-3 DAC Conversion Started by Software Write Trigger

#### 6.38.5.5 DAC Output Voltage

Digital inputs are converted to output voltage on a linear conversion between 0 and reference voltage  $V_{REF}$ . The analog output voltage on DAC pin is determined by the following equation:

$$DACOUT = V_{REF} * \frac{DATnOUT[11:0]}{4096}, n=0,1$$

#### 6.38.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, or EPWM 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.38-4 DAC Conversion Started by Hardware Trigger Event

#### 6.38.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 DAC0\_CTL and DAC0\_TCTL. Figure 6.38-5 shows an example of group mode and compared with normal mode.



Figure 6.38-5 DAC0 and DAC1 Group and Ungroup Update Example

#### 6.38.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.38-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.38-6 DAC PDMA Under-Run Condition Example

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.38-7 provide an example of DAC continuous conversion with software PDMA mode. Note that n=0,1.



Figure 6.38-7 DAC Continuous Conversion with Software PDMA Mode

### 6.38.5.9 Interrupt Sources

There are two interrupt sources in DAC controller, one is DAC data conversion finish interrupt and the other is DMA under-run interrupt as shown in Figure 6.38-8. When DAC conversion finish, the FINISH (DACn\_STATUS[0]) is set to 1 and an interrupt occurs while DACIEN (DACn\_CTL[1]) is enabled. If 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 n=0,1.



Figure 6.38-8 DAC Interrupt Source

### 6.38.6 Register Map

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

| Register                    | Offset      | R/W | Description                            | Reset Value |
|-----------------------------|-------------|-----|----------------------------------------|-------------|
| <b>DAC Base Address:</b>    |             |     |                                        |             |
| <b>DAC_BA = 0x4004_7000</b> |             |     |                                        |             |
| <b>DAC0_CTL</b>             | DAC_BA+0x00 | R/W | DAC0 Control Register                  | 0x0000_0000 |
| <b>DAC0_SWTRG</b>           | DAC_BA+0x04 | R/W | DAC0 Software Trigger Control Register | 0x0000_0000 |
| <b>DAC0_DAT</b>             | DAC_BA+0x08 | R/W | DAC0 Data Holding Register             | 0x0000_0000 |
| <b>DAC0_DATOUT</b>          | DAC_BA+0x0C | R   | DAC0 Data Output Register              | 0x0000_0000 |
| <b>DAC0_STATUS</b>          | DAC_BA+0x10 | R/W | DAC0 Status Register                   | 0x0000_0000 |
| <b>DAC0_TCTL</b>            | DAC_BA+0x14 | R/W | DAC0 Timing Control Register           | 0x0000_0000 |
| <b>DAC1_CTL</b>             | DAC_BA+0x40 | R/W | DAC1 Control Register                  | 0x0000_0000 |
| <b>DAC1_SWTRG</b>           | DAC_BA+0x44 | R/W | DAC1 Software Trigger Control Register | 0x0000_0000 |
| <b>DAC1_DAT</b>             | DAC_BA+0x48 | R/W | DAC1 Data Holding Register             | 0x0000_0000 |
| <b>DAC1_DATOUT</b>          | DAC_BA+0x4C | R   | DAC1 Data Output Register              | 0x0000_0000 |
| <b>DAC1_STATUS</b>          | DAC_BA+0x50 | R/W | DAC1 Status Register                   | 0x0000_0000 |
| <b>DAC1_TCTL</b>            | DAC_BA+0x54 | R/W | DAC1 Timing Control Register           | 0x0000_0000 |

### 6.38.7 Register Description

#### DAC0 Control Register (DAC0\_CTL)

| Register | Offset      | R/W | Description           |  |  |  | Reset Value |
|----------|-------------|-----|-----------------------|--|--|--|-------------|
| DAC0_CTL | DAC_BA+0x00 | R/W | DAC0 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      |
| BWSEL    |    | ETRGSEL |       | Reserved | LALIGN | Reserved | BYPASS |
| 7        | 6  | 5       | 4     | 3        | 2      | 1        | 0      |
| TRGSEL   |    |         | TRGEN | DMAURIEN | DMAEN  | DACIEN   | DACEN  |

| Bits    | Description |                                                                                                                                                         |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                               |
| [16]    | GRPEN       | <b>DAC Group Mode Enable Bit</b><br>0 = DAC0 and DAC1 are not grouped.<br>1 = DAC0 and DAC1 are grouped.                                                |
| [15:14] | BWSEL       | <b>DAC Data Bit-width Selection</b><br>00 = data is 12 bits.<br>01 = data is 8 bits.<br>Others = reserved.                                              |
| [13:12] | ETRGSEL     | <b>External Pin Trigger Selection</b><br>00 = Low level trigger.<br>01 = High level trigger.<br>10 = Falling edge trigger.<br>11 = Rising edge trigger. |
| [11]    | Reserved    | Reserved.                                                                                                                                               |
| [10]    | LALIGN      | <b>DAC Data Left-aligned Enabled Control</b><br>0 = Right alignment.<br>1 = Left alignment.                                                             |
| [9]     | Reserved    | Reserved.                                                                                                                                               |
| [8]     | BYPASS      | <b>Bypass Buffer Mode</b><br>0 = Output voltage buffer Enabled.<br>1 = Output voltage buffer Disabled.                                                  |
| [7:5]   | TRGSEL      | <b>Trigger Source Selection</b><br>000 = Software trigger.<br>001 = External pin DAC0_ST trigger.                                                       |

|     |                 |                                                                                                                                                      |
|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                 | 010 = Timer 0 trigger.<br>011 = Timer 1 trigger.<br>100 = Timer 2 trigger.<br>101 = Timer 3 trigger.<br>110 = EPWM0 trigger.<br>111 = EPWM1 trigger. |
| [4] | <b>TRGEN</b>    | <b>Trigger Mode Enable Bit</b><br>0 = DAC event trigger mode Disabled.<br>1 = DAC event trigger mode Enabled.                                        |
| [3] | <b>DMAURIEN</b> | <b>DMA Under-run Interrupt Enable Bit</b><br>0 = DMA under-run interrupt Disabled.<br>1 = DMA under-run interrupt Enabled.                           |
| [2] | <b>DMAEN</b>    | <b>DMA Mode Enable Bit</b><br>0 = DMA mode Disabled.<br>1 = DMA mode Enabled.                                                                        |
| [1] | <b>DACIEN</b>   | <b>DAC Interrupt Enable Bit</b><br>0 = DAC interrupt Disabled.<br>1 = DAC interrupt Enabled.                                                         |
| [0] | <b>DACEN</b>    | <b>DAC Enable Bit</b><br>0 = DAC Disabled.<br>1 = DAC Enabled.                                                                                       |

DAC0 Software Trigger Control Register (DAC0\_SWTRG)

| Register   | Offset      | R/W | Description                            |  |  |  |  | Reset Value |
|------------|-------------|-----|----------------------------------------|--|--|--|--|-------------|
| DAC0_SWTRG | DAC_BA+0x04 | R/W | DAC0 Software Trigger Control Register |  |  |  |  | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                     |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                           |
| [0]    | SWTRG       | <p><b>Software Trigger</b><br/>           0 = Software trigger Disabled.<br/>           1 = Software trigger Enabled.</p> <p><b>Note:</b> User writes this bit to generate one shot pulse and it is cleared to 0 by hardware automatically; reading this bit will always get 0.</p> |

DAC0 Data Holding Register (DAC0\_DAT)

| Register | Offset      | R/W | Description                |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------|--|--|--|-------------|
| DAC0_DAT | DAC_BA+0x08 | R/W | DAC0 Data Holding 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  |
| DACC DAT |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| DACC DAT |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [15:0]  | DACC DAT    | <p><b>DAC 12-bit Holding Data</b></p> <p>These bits are written by user software which specifies 12-bit conversion data for DAC output. The unused bits (DAC_DAT[3:0] in left-alignment mode and DAC_DAT[15:12] in right alignment mode) are ignored by DAC controller hardware.</p> <p>12 bit left alignment: user has to load data into DAC_DAT[15:4] bits.</p> <p>12 bit right alignment: user has to load data into DAC_DAT[11:0] bits.</p> |

DAC0 Data Output Register (DAC0\_DATOUT)

| Register    | Offset      | R/W | Description               | Reset Value |
|-------------|-------------|-----|---------------------------|-------------|
| DAC0_DATOUT | DAC_BA+0x0C | R   | DAC0 Data Output Register | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                |
| [11:0]  | DATOUT      | <b>DAC 12-bit Output Data</b><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 (DAC0\_STATUS)

| Register    | Offset      | R/W | Description          |  |  |  | Reset Value |
|-------------|-------------|-----|----------------------|--|--|--|-------------|
| DAC0_STATUS | DAC_BA+0x10 | R/W | DAC0 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 |    |    |    |    |    | DMAUDR | FINISH |

| Bits   | Description |                                                                                                                                                                                                                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                   |
| [8]    | BUSY        | <b>DAC Busy Flag (Read Only)</b><br>0 = DAC is ready for next conversion.<br>1 = DAC is busy in conversion.                                                                                                                                                                                 |
| [7:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                   |
| [1]    | DMAUDR      | <b>DMA Under-run Interrupt Flag</b><br>0 = No DMA under-run error condition occurred.<br>1 = DMA under-run error condition occurred.<br><b>Note:</b> User writes 1 to clear this bit.                                                                                                       |
| [0]    | FINISH      | <b>DAC Conversion Complete Finish Flag</b><br>0 = DAC is in conversion state.<br>1 = DAC conversion finish.<br><b>Note:</b> This bit is set to 1 when conversion time counter counts to SETTLET. It is cleared to 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+0x14 | R/W | DAC0 Timing 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 |    |    |    |    |    | SETTLET |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1       | 0  |
| SETTLET  |    |    |    |    |    |         |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                               |
| [9:0]   | SETTLET     | <p><b>DAC Output Settling Time</b></p> <p>User software needs to write appropriate value to these bits to meet DAC conversion settling time base on PCLK (APB clock) speed.</p> <p>For example, DAC controller clock speed is 80MHz and DAC conversion settling time is 1 us, SETTLETvalue must be greater than 0x50.</p> <p>SELTTLET = DAC controller clock speed x settling time.</p> |

**DAC1 Control Register (DAC1\_CTL)**

| Register | Offset      | R/W | Description           |  |  |  | Reset Value |
|----------|-------------|-----|-----------------------|--|--|--|-------------|
| DAC1_CTL | DAC_BA+0x40 | R/W | DAC1 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      |
| 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       | <b>DAC Data Bit-width Selection</b><br>00 = Data is 12 bits.<br>01 = Data is 8 bits.<br>Others = reserved.                                                                                                                        |
| [13:12] | ETRGSEL     | <b>External Pin Trigger Selection</b><br>00 = Low level trigger.<br>01 = High level trigger.<br>10 = Falling edge trigger.<br>11 = Rising edge trigger.                                                                           |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                         |
| [10]    | LALIGN      | <b>DAC Data Left-aligned Enabled Control</b><br>0 = Right alignment.<br>1 = Left alignment.                                                                                                                                       |
| [9]     | Reserved    | Reserved.                                                                                                                                                                                                                         |
| [8]     | BYPASS      | <b>Bypass Buffer Mode</b><br>0 = Output voltage buffer Enabled.<br>1 = Output voltage buffer Disabled.                                                                                                                            |
| [7:5]   | TRGSEL      | <b>Trigger Source Selection</b><br>000 = Software trigger.<br>001 = External pin DAC1_ST trigger.<br>010 = Timer 0 trigger.<br>011 = Timer 1 trigger.<br>100 = Timer 2 trigger.<br>101 = Timer 3 trigger.<br>110 = EPWM0 trigger. |

|     |                 |                                                                                                                            |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------|
|     |                 | 111 = EPWM1 trigger.                                                                                                       |
| [4] | <b>TRGEN</b>    | <b>Trigger Mode Enable Bit</b><br>0 = DAC event trigger mode Disabled.<br>1 = DAC event trigger mode Enabled.              |
| [3] | <b>DMAURIEN</b> | <b>DMA Under-run Interrupt Enable Bit</b><br>0 = DMA under-run interrupt Disabled.<br>1 = DMA under-run interrupt Enabled. |
| [2] | <b>DMAEN</b>    | <b>DMA Mode Enable Bit</b><br>0 = DMA mode Disabled.<br>1 = DMA mode Enabled.                                              |
| [1] | <b>DACIEN</b>   | <b>DAC Interrupt Enable Bit</b><br>0 = DAC interrupt Disabled.<br>1 = DAC interrupt Enabled.                               |
| [0] | <b>DACEN</b>    | <b>DAC Enable Bit</b><br>0 = DAC Disabled.<br>1 = DAC Enabled.                                                             |

DAC1 Software Trigger Control Register (DAC1\_SWTRG)

| Register   | Offset      | R/W | Description                            | Reset Value |
|------------|-------------|-----|----------------------------------------|-------------|
| DAC1_SWTRG | DAC_BA+0x44 | R/W | DAC1 Software Trigger Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                     |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                           |
| [0]    | SWTRG       | <p><b>Software Trigger</b><br/>           0 = Software trigger Disabled.<br/>           1 = Software trigger Enabled.</p> <p><b>Note:</b> User writes this bit to generate one shot pulse and it is cleared to 0 by hardware automatically; Reading this bit will always get 0.</p> |

DAC1 Data Holding Register (DAC1\_DAT)

| Register | Offset      | R/W | Description                |  |  |  | Reset Value |
|----------|-------------|-----|----------------------------|--|--|--|-------------|
| DAC1_DAT | DAC_BA+0x48 | R/W | DAC1 Data Holding 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  |
| DACDAT   |    |    |    |    |    |    |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| DACDAT   |    |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [15:0]  | DACDAT      | <p><b>DAC 12-bit Holding Data</b></p> <p>These bits are written by user software which specifies 12-bit conversion data for DAC output. The unused bits (DAC_DAT[3:0] in left-alignment mode and DAC_DAT[15:12] in right alignment mode) are ignored by DAC controller hardware.</p> <p>12 bit left alignment: user has to load data into DAC_DAT[15:4] bits.</p> <p>12 bit right alignment: user has to load data into DAC_DAT[11:0] bits.</p> |

DAC1 Data Output Register (DAC1\_DATOUT)

| Register    | Offset      | R/W | Description               | Reset Value |
|-------------|-------------|-----|---------------------------|-------------|
| DAC1_DATOUT | DAC_BA+0x4C | R   | DAC1 Data Output Register | 0x0000_0000 |



| Bits    | Description |                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                |
| [11:0]  | DATOUT      | <b>DAC 12-bit Output Data</b><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_STATUS | DAC_BA+0x50 | R/W | DAC1 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 |    |    |    |    |    | DMAUDR | FINISH |

| Bits   | Description |                                                                                                                                                                                                                                                                                          |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |
| [8]    | BUSY        | <b>DAC Busy Flag (Read Only)</b><br>0 = DAC is ready for next conversion.<br>1 = DAC is busy in conversion.                                                                                                                                                                              |
| [7:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |
| [1]    | DMAUDR      | <b>DMA Under-run Interrupt Flag</b><br>0 = No DMA under-run error condition occurred.<br>1 = DMA under-run error condition occurred.<br><b>Note:</b> User writes 1 to clear this bit.                                                                                                    |
| [0]    | FINISH      | <b>DAC Conversion Complete Finish Flag</b><br>0 = DAC is in conversion state.<br>1 = DAC conversion finish.<br><b>Note:</b> This bit set to 1 when conversion time counter counts to SETTLET. It is cleared to 0 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+0x54 | R/W | DAC1 Timing 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 |    |    |    |    |    | SETTLET |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1       | 0  |
| SETTLET  |    |    |    |    |    |         |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                               |
| [9:0]   | SETTLET     | <p><b>DAC Output Settling Time</b></p> <p>User software needs to write appropriate value to these bits to meet DAC conversion settling time base on PCLK (APB clock) speed.</p> <p>For example, DAC controller clock speed is 80MHz and DAC conversion settling time is 1 us, SETTLET value must be greater than 0x50.</p> <p>SELTTLET = DAC controller clock speed x setting time.</p> |

## 6.39 Analog Comparator Controller (ACMP)

### 6.39.1 Overview

The chip provides 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.39.2 Features

- Analog input voltage range: 0 ~ AVDD (voltage of AVDD pin)
- Up to two rail-to-rail analog comparators
- Supports hysteresis function
  - Supports programmable hysteresis window: 0mV, 10mV, 20mV and 30mV
- Supports wake-up function
- Supports programmable propagation speed and low power consumption
- Selectable input sources of positive input and negative input
- ACMP0 supports:
  - 4 multiplexed I/O pins at positive sources:
    - ◆ ACMP0\_P0, ACMP0\_P1, ACMP0\_P2, or ACMP0\_P3
  - 4 negative sources:
    - ◆ ACMP0\_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)
    - ◆ DAC0 output (DAC0\_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 EPWM
- Supports window compare mode and window latch mode

### 6.39.3 Block Diagram



Figure 6.39-1 Analog Comparator Block Diagram

### 6.39.4 Basic Configuration

#### 6.39.4.1 ACMP0 Basic Configuration

- Clock source Configuration
  - Enable ACMP0 peripheral clock in ACMP01CKEN (CLK\_APBCLK0[7]).
- Reset Configuration
  - Reset ACMP0 controller in ACMP01RST (SYS\_IPRST1[7]).
- Pin configuration

| Group | Pin Name   | GPIO        | MFP   |
|-------|------------|-------------|-------|
| ACMP0 | ACMP0_N    | PB.3        | MFP1  |
|       | ACMP0_O    | PC.1, PC.12 | MFP14 |
|       |            | PB.7        | MFP15 |
|       | ACMP0_P0   | PA.11       | MFP1  |
|       | ACMP0_P1   | PB.2        | MFP1  |
|       | ACMP0_P2   | PB.12       | MFP1  |
|       | ACMP0_P3   | PB.13       | MFP1  |
|       | ACMP0_WLAT | PA.7        | MFP13 |

#### 6.39.4.2 ACMP1 Basic Configuration

- Clock source Configuration
  - Enable ACMP1 peripheral clock in ACMP01CKEN (CLK\_APBCLK0[7]).

- Reset Configuration
  - Reset ACMP1 controller in ACMP01RST (SYS\_IPRST1[7]).
- Pin configuration

| Group | Pin Name   | GPIO        | MFP   |
|-------|------------|-------------|-------|
| ACMP1 | ACMP1_N    | PB.5        | MFP1  |
|       | ACMP1_O    | PC.0, PC.11 | MFP14 |
|       |            | PB.6        | MFP15 |
|       | ACMP1_P0   | PA.10       | MFP1  |
|       | ACMP1_P1   | PB.4        | MFP1  |
|       | ACMP1_P2   | PB.12       | MFP1  |
|       | ACMP1_P3   | PB.13       | MFP1  |
|       | ACMP1_WLAT | PA.6        | MFP13 |

### 6.39.5 Functional Description

#### 6.39.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.39-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.39-2 Comparator Hysteresis Function of ACMP0

#### 6.39.5.2 Window Latch Mode

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



Figure 6.39-3 Window Latch Mode

#### 6.39.5.3 Filter Function

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

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

Figure 6.39-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 ACMPO0. If the comparing result is shorter than 4 PCLK, it will be filtered.



Figure 6.39-4 An example of filter function

#### 6.39.5.4 Interrupt Sources

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

WKIF(ACMP\_STATUS[8], ACMP\_STATUS[9]) will be set according to the setting of INTPOL (ACMP\_CTL0/1[9:8]) if ACMP wakeup function is enabled. These two flags also cause interrupt rising that makes system wakeup from power down by ACMP.

Figure 6.39-5 shows the interrupts sources of ACMP.



Figure 6.39-5 Comparator Controller Interrupt

#### 6.39.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\_CTL0[5:4], ACMP\_CTL1[5:4]). Figure 6.39-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 AVDD pin or the INT\_VREF voltage which is controlled by SYS\_VREFCTL register.



Figure 6.39-6 Comparator Reference Voltage Block Diagram

#### 6.39.5.6 Window Compare Mode

The comparator provides window compare mode. When window compare mode is enabled by setting WCMPSL (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.39-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 ACMPS0 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 is in the window. Otherwise, the voltage source is outside the window.



Figure 6.39-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.39-1.

| ACMPS0 | ACMPS1 | ACMPWO |
|--------|--------|--------|
| 0      | 0      | 0      |
| 0      | 1      | 1      |
| 1      | 1      | 0      |
| 1      | 0      | 1      |

Table 6.39-1 Truth Table of Window Compare Logic



Figure 6.39-8 Example of Window Compare Mode

As shown in Figure 6.39-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.39.6 Register Map

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

| Register                       | Offset         | R/W | Description                                          | Reset Value |
|--------------------------------|----------------|-----|------------------------------------------------------|-------------|
| <b>ACMP Base Address:</b>      |                |     |                                                      |             |
| <b>ACMP01_BA = 0x4004_5000</b> |                |     |                                                      |             |
| <b>ACMP_CTL0</b>               | ACMP01_BA+0x00 | R/W | Analog Comparator 0 Control Register                 | 0x0000_0000 |
| <b>ACMP_CTL1</b>               | ACMP01_BA+0x04 | R/W | Analog Comparator 1 Control Register                 | 0x0000_0000 |
| <b>ACMP_STATUS</b>             | ACMP01_BA+0x08 | R/W | Analog Comparator Status Register                    | 0x0000_0000 |
| <b>ACMP_VREF</b>               | ACMP01_BA+0x0C | R/W | Analog Comparator Reference Voltage Control Register | 0x0000_0000 |

### 6.39.7 Register Description

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

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

|          |    |         |        |          |          |        |        |
|----------|----|---------|--------|----------|----------|--------|--------|
| 31       | 30 | 29      | 28     | 27       | 26       | 25     | 24     |
| 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     | <b>Propagation Delay Mode Selection</b><br>00 = Max propagation delay is 4.5uS, operation current is 1.2uA.<br>01 = Max propagation delay is 2uS, operation current is 3uA.<br>10 = Max propagation delay is 600nS, operation current is 10uA.<br>11 = Max propagation delay is 200nS, operation current is 75uA. |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [25:24] | HYSSEL      | <b>Hysteresis Mode Selection</b><br>00 = Hysteresis is 0mV.<br>01 = Hysteresis is 10mV.<br>10 = Hysteresis is 20mV.<br>11 = Hysteresis is 30mV.                                                                                                                                                                   |
| [23:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [18]    | WCMPSEL     | <b>Window Compare Mode Selection</b><br>0 = Window Compare Mode Disabled.<br>1 = Window Compare Mode is Selected.                                                                                                                                                                                                 |
| [17]    | WLATEN      | <b>Window Latch Mode Enable Bit</b><br>0 = Window Latch Mode Disabled.<br>1 = Window Latch Mode Enabled.                                                                                                                                                                                                          |
| [16]    | WKEN        | <b>Power-down Wake-up Enable Bit</b><br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                                                                                                                                                                           |
| [15:13] | FILTSEL     | <b>Comparator Output Filter Count Selection</b><br>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 = ACMP0 output is sampled 8 consecutive PCLKs.<br>101 = ACMP0 output is sampled 16 consecutive PCLKs.<br>110 = ACMP0 output is sampled 32 consecutive PCLKs.<br>111 = ACMP0 output is sampled 64 consecutive PCLKs. |
| [12]    | <b>OUTSEL</b>   | <b>Comparator Output Select</b><br>0 = Comparator 0 output to ACMP0_O pin is unfiltered comparator output.<br>1 = Comparator 0 output to ACMP0_O pin is from filter output.                                                                                                                                                         |
| [11:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                           |
| [9:8]   | <b>INTPOL</b>   | <b>Interrupt Condition Polarity Selection</b><br>ACMPIF0 will be set to 1 when comparator output edge condition is detected.<br>00 = Rising edge or falling edge.<br>01 = Rising edge.<br>10 = Falling edge.<br>11 = Reserved.                                                                                                      |
| [7:6]   | <b>POSSEL</b>   | <b>Comparator Positive Input Selection</b><br>00 = Input from ACMP0_P0.<br>01 = Input from ACMP0_P1.<br>10 = Input from ACMP0_P2.<br>11 = Input from ACMP0_P3.                                                                                                                                                                      |
| [5:4]   | <b>NEGSEL</b>   | <b>Comparator Negative Input Selection</b><br>00 = ACMP0_N pin.<br>01 = Internal comparator reference voltage (CRV).<br>10 = Band-gap voltage.<br>11 = DAC output.                                                                                                                                                                  |
| [3]     | <b>ACMPOINV</b> | <b>Comparator Output Inverse</b><br>0 = Comparator 0 output inverse Disabled.<br>1 = Comparator 0 output inverse Enabled.                                                                                                                                                                                                           |
| [2]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                           |
| [1]     | <b>ACMPIE</b>   | <b>Comparator Interrupt Enable Bit</b><br>0 = Comparator 0 interrupt Disabled.<br>1 = Comparator 0 interrupt Enabled. If WKEN (ACMP_CTL0[16]) is set to 1, the wake-up interrupt function will be enabled as well.                                                                                                                  |
| [0]     | <b>ACMPEN</b>   | <b>Comparator Enable Bit</b><br>0 = Comparator 0 Disabled.<br>1 = Comparator 0 Enabled.                                                                                                                                                                                                                                             |

Analog Comparator 1 Control Register (ACMP\_CTL1)

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

|          |    |         |        |          |          |        |        |
|----------|----|---------|--------|----------|----------|--------|--------|
| 31       | 30 | 29      | 28     | 27       | 26       | 25     | 24     |
| 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     | <b>Propagation Delay Mode Selection</b><br>00 = Max propagation delay is 4.5uS, operation current is 1.2uA.<br>01 = Max propagation delay is 2uS, operation current is 3uA.<br>10 = Max propagation delay is 600nS, operation current is 10uA.<br>11 = Max propagation delay is 200nS, operation current is 75uA. |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [25:24] | HYSSEL      | <b>Hysteresis Mode Selection</b><br>00 = Hysteresis is 0mV.<br>01 = Hysteresis is 10mV.<br>10 = Hysteresis is 20mV.<br>11 = Hysteresis is 30mV.                                                                                                                                                                   |
| [23:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                         |
| [18]    | WCMPSEL     | <b>Window Compare Mode Selection</b><br>0 = Window Compare Mode Disabled.<br>1 = Window Compare Mode is Selected.                                                                                                                                                                                                 |
| [17]    | WLATEN      | <b>Window Latch Mode Enable Bit</b><br>0 = Window Latch Mode Disabled.<br>1 = Window Latch Mode Enabled.                                                                                                                                                                                                          |
| [16]    | WKEN        | <b>Power-down Wakeup Enable Bit</b><br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                                                                                                                                                                            |

| Bits    | Description     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:13] | <b>FILTSEL</b>  | <p><b>Comparator Output Filter Count Selection</b></p> <p>000 = Filter function is Disabled.</p> <p>001 = ACMP1 output is sampled 1 consecutive PCLK.</p> <p>010 = ACMP1 output is sampled 2 consecutive PCLKs.</p> <p>011 = ACMP1 output is sampled 4 consecutive PCLKs.</p> <p>100 = ACMP1 output is sampled 8 consecutive PCLKs.</p> <p>101 = ACMP1 output is sampled 16 consecutive PCLKs.</p> <p>110 = ACMP1 output is sampled 32 consecutive PCLKs.</p> <p>111 = ACMP1 output is sampled 64 consecutive PCLKs.</p> |
| [12]    | <b>OUTSEL</b>   | <p><b>Comparator Output Select</b></p> <p>0 = Comparator 1 output to ACMP1_O pin is unfiltered comparator output.</p> <p>1 = Comparator 1 output to ACMP1_O pin is from filter output.</p>                                                                                                                                                                                                                                                                                                                               |
| [11:10] | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [9:8]   | <b>INTPOL</b>   | <p><b>Interrupt Condition Polarity Selection</b></p> <p>ACMPIF1 will be set to 1 when comparator output edge condition is detected.</p> <p>00 = Rising edge or falling edge.</p> <p>01 = Rising edge.</p> <p>10 = Falling edge.</p> <p>11 = Reserved.</p>                                                                                                                                                                                                                                                                |
| [7:6]   | <b>POSSEL</b>   | <p><b>Comparator Positive Input Selection</b></p> <p>00 = Input from ACMP1_P0.</p> <p>01 = Input from ACMP1_P1.</p> <p>10 = Input from ACMP1_P2.</p> <p>11 = Input from ACMP1_P3.</p>                                                                                                                                                                                                                                                                                                                                    |
| [5:4]   | <b>NEGSEL</b>   | <p><b>Comparator Negative Input Selection</b></p> <p>00 = ACMP1_N pin.</p> <p>01 = Internal comparator reference voltage (CRV).</p> <p>10 = Band-gap voltage.</p> <p>11 = DAC output.</p>                                                                                                                                                                                                                                                                                                                                |
| [3]     | <b>ACMPOINV</b> | <p><b>Comparator Output Inverse Control</b></p> <p>0 = Comparator 1 output inverse Disabled.</p> <p>1 = Comparator 1 output inverse Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                         |
| [2]     | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [1]     | <b>ACMPIE</b>   | <p><b>Comparator Interrupt Enable Bit</b></p> <p>0 = Comparator 1 interrupt Disabled.</p> <p>1 = Comparator 1 interrupt Enabled. If WKEN (ACMP_CTL1[16]) is set to 1, the wake-up interrupt function will be enabled as well.</p>                                                                                                                                                                                                                                                                                        |
| [0]     | <b>ACMPEN</b>   | <p><b>Comparator Enable Bit</b></p> <p>0 = Comparator 1 Disabled.</p> <p>1 = Comparator 1 Enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Analog Comparator Status Register (ACMP\_STATUS)**

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

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

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

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

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

| Register  | Offset         | R/W | Description                                          |  |  |  |  | Reset Value |
|-----------|----------------|-----|------------------------------------------------------|--|--|--|--|-------------|
| ACMP_VREF | ACMP01_BA+0x0C | R/W | Analog Comparator Reference Voltage Control Register |  |  |  |  | 0x0000_0000 |

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

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

## 6.40 OP Amplifier (OPA)

### 6.40.1 Overview

This device is equipped with three operational amplifiers. Users can enable each of them individually, by their application purpose. PB.2 is connected to ADC0\_CH2 and OPA0\_O internally. User can read OPA output data from ADC.

### 6.40.2 Features

- Analog input voltage range: 0~VDD.
- Supports up to 3 operator amplifiers.
- Supports to use Schmitt trigger buffer output for simple comparator function.
- Supports to Schmitt trigger buffer output interrupts.

### 6.40.3 Block Diagram



Figure 6.40-1 OP Amplifier Block Diagram

### 6.40.4 Basic Configuration

#### 6.40.4.1 OPA0 Basic Configuration

- Clock source Configuration

- Enable OPA0 peripheral clock in OPACKEN (CLK\_APBCLK1[30]).
- Reset Configuration
  - Reset OPA0 controller in OPARST (SYS\_IPRST2[30]).
- Pin configuration

| Group | Pin Name | GPIO | MFP  |
|-------|----------|------|------|
| OPA0  | OPA0_N   | PB.1 | MFP1 |
|       | OPA0_O   | PB.2 | MFP1 |
|       | OPA0_P   | PB.0 | MFP1 |

#### 6.40.4.2 OPA1 Basic Configuration

- Clock source Configuration
  - Enable OPA1 peripheral clock in OPACKEN (CLK\_APBCLK1[30]).
- Reset Configuration
  - Reset OPA1 controller in OPARST (SYS\_IPRST2[30]).
- Pin configuration

| Group | Pin Name | GPIO  | MFP  |
|-------|----------|-------|------|
| OPA1  | OPA1_N   | PA.9  | MFP1 |
|       | OPA1_O   | PA.10 | MFP1 |
|       | OPA1_P   | PA.8  | MFP1 |

#### 6.40.4.3 OPA2 Basic Configuration

- Clock source Configuration
  - Enable OPA2 peripheral clock in OPACKEN (CLK\_APBCLK1[30]).
- Reset Configuration
  - Reset OPA2 controller in OPARST (SYS\_IPRST2[30]).
- Pin configuration

| Group | Pin Name | GPIO  | MFP  |
|-------|----------|-------|------|
| OPA2  | OPA2_N   | PD.11 | MFP1 |
|       | OPA2_O   | PD.12 | MFP1 |
|       | OPA2_P   | PD.10 | MFP1 |

### 6.40.5 Functional Description

#### 6.40.5.1 OP Amplifier Function

The OP amplifier can be enabled by setting OPENx (OPA\_CTL[2:0]) bits where x=0, 1, 2 for OPA0, OPA1, OPA2 respectively. The OPA pin functions can refer to Figure 6.40-1 and OPA0 output is also internally connected to ADC channel for measurement requirement. Schmitt trigger enable can be set by setting OPDOENx (OPA\_CTL[6:4]) bits. OP amplifiers digital output OPDOx (OPA\_STATUS[2:0]) are set only when the output state of OP amplifiers changes and Schmitt trigger enable bits are set. OP amplifier digital output is always be 0 when the Schmitt trigger buffer is disabled.

#### 6.40.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... The circuit has five trim bits which can be used to calibrate the offset voltage. Offset voltage comes from both mismatch of NMOS-type differential and PMOS-type differential input stages. Calibration can be started by setting CALTRGx (OPA\_CALCTL[2:0]) and set CALCLKx (OPA\_CALCTL[9:4] to 2'b00, x=0, 1, 2. After calibration, the input voltage offset can be reduced to be within  $\pm 1.6\text{mV}(\text{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 include calibration done status, NMOS, and PMOS calibration result status. Take a brief calibration flow for example: Once OPENx (OPA\_CTL[2: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 CALTRGx (OPA\_CALCTL[2:0]) to start calibration function getting newer offset trim values, or OP amplifier will operate with older offset trim values. It is noted that x=0, 1, 2.

#### 6.40.5.3 Interrupt Sources

OPDOIF0 (OPA\_STATUS[4]) and OPDOIF1 (OPA\_STATUS[5]), OPDOIF2 (OPA\_STATUS[6]) interrupt flag are set respectively by hardware whenever digital output interrupt enable OPDOIEN0 (OPA\_CTL[8]), OPDOIEN1 (OPA\_CTL[9]), OPDOIEN2 (OPA\_CTL[10]) are set the OPA0, 1, 2 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, 1, 2 can be as one of the comparator interrupt sources.

#### 6.40.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 |
|-----------------------------|-------------|-----|-------------------------------------------|-------------|
| <b>OPA Base Address:</b>    |             |     |                                           |             |
| <b>OPA_BA = 0x4004_6000</b> |             |     |                                           |             |
| <b>OPA_CTL</b>              | OPA_BA+0x00 | R/W | OP Amplifier Control Register             | 0x0000_0000 |
| <b>OPA_STATUS</b>           | OPA_BA+0x04 | R/W | OP Amplifier Status Register              | 0x0000_0000 |
| <b>OPA_CALCTL</b>           | OPA_BA+0x08 | R/W | OP Amplifier Calibration Control Register | 0x0000_03F0 |
| <b>OPA_CALST</b>            | OPA_BA+0x0C | R   | OP Amplifier Calibration Status Register  | 0x0000_0000 |

### 6.40.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 |  |  |  | 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 |          |          |          |          | OPDOIEN2 | OPDOIEN1 | OPDOIENO |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved | OPDOIEN2 | OPDOIEN1 | OPDOIENO | Reserved | OPEN2    | OPEN1    | OPEN0    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [10]    | OPDOIEN2    | <b>OP Amplifier 2 Schmitt Trigger Digital Output Interrupt Enable Bit</b><br>0 = OP Amplifier 2 digital output interrupt function Disabled.<br>1 = OP Amplifier 2 digital output interrupt function Enabled.<br><b>Note:</b> The OPDOI2 interrupt flag is set by hardware whenever the OP amplifier 2 Schmitt trigger non-inverting buffer digital output changes state, in the meanwhile, if OPDOIEN2 is set to 1, a comparator interrupt request is generated. |
| [9]     | OPDOIEN1    | <b>OP Amplifier 1 Schmitt Trigger Digital Output Interrupt Enable Bit</b><br>0 = OP Amplifier 1 digital output interrupt function Disabled.<br>1 = OP Amplifier 1 digital output interrupt function Enabled.<br><b>Note:</b> The OPDOI1 interrupt flag is set by hardware whenever the OP amplifier 1 Schmitt trigger non-inverting buffer digital output changes state, in the meanwhile, if OPDOIEN1 is set to 1, a comparator interrupt request is generated. |
| [8]     | OPDOIENO    | <b>OP Amplifier 0 Schmitt Trigger Digital Output Interrupt Enable Bit</b><br>0 = OP Amplifier 0 digital output interrupt function Disabled.<br>1 = OP Amplifier 0 digital output interrupt function Enabled.<br><b>Note:</b> The OPDOI0 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]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [6]     | OPDOIEN2    | <b>OP Amplifier 2 Schmitt Trigger Non-inverting Buffer Enable Bit</b><br>0 = OP amplifier2 schmitt trigger non-invert buffer Disabled.<br>1 = OP amplifier2 schmitt trigger non-invert buffer Enabled.                                                                                                                                                                                                                                                           |
| [5]     | OPDOIEN1    | <b>OP Amplifier 1 Schmitt Trigger Non-inverting Buffer Enable Bit</b><br>0 = OP amplifier1 schmitt trigger non-invert buffer Disabled.<br>1 = OP amplifier1 schmitt trigger non-invert buffer Enabled.                                                                                                                                                                                                                                                           |

| Bits | Description     |                                                                                                                                                                                                        |
|------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4]  | <b>OPDOEN0</b>  | <b>OP Amplifier 0 Schmitt Trigger Non-inverting Buffer Enable Bit</b><br>0 = OP amplifier0 schmitt trigger non-invert buffer Disabled.<br>1 = OP amplifier0 schmitt trigger non-invert buffer Enabled. |
| [3]  | <b>Reserved</b> | Reserved.                                                                                                                                                                                              |
| [2]  | <b>OPEN2</b>    | <b>OP Amplifier 2 Enable Bit</b><br>0 = OP amplifier2 Disabled.<br>1 = OP amplifier2 Enabled.<br><b>Note:</b> OP Amplifier 2 output needs wait stable 20µs after OPEN2 is set.                         |
| [1]  | <b>OPEN1</b>    | <b>OP Amplifier 1 Enable Bit</b><br>0 = OP amplifier1 Disabled.<br>1 = OP amplifier1 Enabled.<br><b>Note:</b> OP Amplifier 1 output needs wait stable 20µs after OPEN1 is set.                         |
| [0]  | <b>OPEN0</b>    | <b>OP Amplifier 0 Enable Bit</b><br>0 = OP amplifier0 Disabled.<br>1 = OP amplifier0 Enabled.<br><b>Note:</b> OP Amplifier 0 output needs wait stable 20µs after OPEN0 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 |  |  |  | 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 | OPDOIF2 | OPDOIF1 | OPDOIF0 | Reserved | OPDO2 | OPDO1 | OPDO0 |

| Bits   | Description |                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [6]    | OPDOIF2     | <b>OP Amplifier 2 Schmitt Trigger Digital Output Interrupt Flag</b><br>OPDOIF2 interrupt flag is set by hardware whenever the OP amplifier 2 Schmitt trigger non-inverting buffer digital output changes state. <b>This bit is cleared by writing 1 to it.</b> |
| [5]    | OPDOIF1     | <b>OP Amplifier 1 Schmitt Trigger Digital Output Interrupt Flag</b><br>OPDOIF1 interrupt flag is set by hardware whenever the OP amplifier 1 Schmitt trigger non-inverting buffer digital output changes state. <b>This bit is cleared by writing 1 to it.</b> |
| [4]    | OPDOIF0     | <b>OP Amplifier 0 Schmitt Trigger Digital Output Interrupt Flag</b><br>OPDOIF0 interrupt flag is set by hardware whenever the OP amplifier 0 Schmitt trigger non-inverting buffer digital output changes state. <b>This bit is cleared by writing 1 to it.</b> |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [2]    | OPDO2       | <b>OP Amplifier 2 Digital Output</b><br>Synchronized to the APB clock to allow reading by software. Cleared when the Schmitt trigger buffer is disabled (OPDOEN2 = 0).                                                                                         |
| [1]    | OPDO1       | <b>OP Amplifier 1 Digital Output</b><br>Synchronized to the APB clock to allow reading by software. Cleared when the Schmitt trigger buffer is disabled (OPDOEN1 = 0).                                                                                         |
| [0]    | OPDO0       | <b>OP Amplifier 0 Digital Output</b><br>Synchronized to the APB clock to allow reading by software. Cleared when the Schmitt trigger buffer is disabled (OPDOEN0 = 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 |  |  |  | 0x0000_03F0 |

|          |    |         |    |          |         |         |         |
|----------|----|---------|----|----------|---------|---------|---------|
| 31       | 30 | 29      | 28 | 27       | 26      | 25      | 24      |
| Reserved |    |         |    |          |         |         |         |
| 23       | 22 | 21      | 20 | 19       | 18      | 17      | 16      |
| Reserved |    |         |    |          | CALRVS2 | CALRVS1 | CALRVS0 |
| 15       | 14 | 13      | 12 | 11       | 10      | 9       | 8       |
| Reserved |    |         |    |          |         | CALCLK2 |         |
| 7        | 6  | 5       | 4  | 3        | 2       | 1       | 0       |
| CALCLK1  |    | CALCLK0 |    | Reserved | CALTRG2 | CALTRG1 | CALTRG0 |

| Bits    | Description |                                                                                                                                           |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | Reserved    | Reserved.                                                                                                                                 |
| [18]    | CALRVS2     | <b>OPA2 Calibration Reference Voltage Selection</b><br>0 = $V_{REF}$ is $\frac{1}{2}AV_{DD}$ .<br>1 = $V_{REF}$ from high vcm to low vcm. |
| [17]    | CALRVS1     | <b>OPA1 Calibration Reference Voltage Selection</b><br>0 = $V_{REF}$ is $\frac{1}{2}AV_{DD}$ .<br>1 = $V_{REF}$ from high vcm to low vcm. |
| [16]    | CALRVS0     | <b>OPA0 Calibration Reference Voltage Selection</b><br>0 = $V_{REF}$ is $\frac{1}{2}AV_{DD}$ .<br>1 = $V_{REF}$ from high vcm to low vcm. |
| [15:10] | Reserved    | Reserved.                                                                                                                                 |
| [9:8]   | CALCLK2     | <b>OP Amplifier 2 Calibration Clock Rate Selection</b><br>00 = 1 kHz.<br>01 = Reserved.<br>10 = Reserved.<br>11 = Reserved.               |
| [7:6]   | CALCLK1     | <b>OP Amplifier 1 Calibration Clock Rate Selection</b><br>00 = 1 kHz.<br>01 = Reserved.<br>10 = Reserved.<br>11 = Reserved.               |

| Bits  | Description     |                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:4] | <b>CALCLK0</b>  | <b>OP Amplifier 0 Calibration Clock Rate Selection</b><br>00 = 1 kHz.<br>01 = Reserved.<br>10 = Reserved.<br>11 = Reserved.                                                                                                                                                                                                                     |
| [3]   | <b>Reserved</b> | Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [2]   | <b>CALTRG2</b>  | <b>OP Amplifier 2 Calibration Trigger Bit</b><br>0 = Calibration is stopped.,<br>1 = Calibration is triggered.<br><b>Note1:</b> Before this bit is enabled, OPEN2 should be set and the internal high speed RC oscillator (HIRC) should be enabled in advance.<br><b>Note2:</b> Hardware will auto clear this bit when calibration is finished. |
| [1]   | <b>CALTRG1</b>  | <b>OP Amplifier 1 Calibration Trigger Bit</b><br>0 = Calibration is stopped.<br>1 = Calibration is triggered.<br><b>Note1:</b> Before this bit is enabled, OPEN1 should be set and the internal high speed RC oscillator (HIRC) should be enabled in advance.<br><b>Note2:</b> Hardware will auto clear this bit when calibration is finished.  |
| [0]   | <b>CALTRG0</b>  | <b>OP Amplifier 0 Calibration Trigger Bit</b><br>0 = Calibration is stopped.<br>1 = Calibration is triggered.<br><b>Note1:</b> Before this bit is enabled, OPEN0 should be set and the internal high speed RC oscillator (HIRC) should be enabled in advance.<br><b>Note2:</b> Hardware will auto clear this bit when calibration is finished.  |

**OPA Calibration Status Register (OPA\_CALST)**

| Register  | Offset      | R/W | Description                              |  |  |  | Reset Value |
|-----------|-------------|-----|------------------------------------------|--|--|--|-------------|
| OPA_CALST | OPA_BA+0x0C | R   | OP Amplifier Calibration 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 |        |        |       |          | CALPS2 | CALNS2 | DONE2 |
| 7        | 6      | 5      | 4     | 3        | 2      | 1      | 0     |
| Reserved | CALPS1 | CALNS1 | DONE1 | Reserved | CALPS0 | CALNS0 | DONE0 |

| Bits    | Description |                                                                                            |
|---------|-------------|--------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                  |
| [10]    | CALPS2      | <b>OP Amplifier 2 Calibration Result Status for PMOS</b><br>0 = Pass.<br>1 = Fail.         |
| [9]     | CALNS2      | <b>OP Amplifier 2 Calibration Result Status for NMOS</b><br>0 = Pass.<br>1 = Fail.         |
| [8]     | DONE2       | <b>OP Amplifier 2 Calibration Done Status</b><br>0 = Calibrating.<br>1 = Calibration Done. |
| [7]     | Reserved    | Reserved.                                                                                  |
| [6]     | CALPS1      | <b>OP Amplifier 1 Calibration Result Status for PMOS</b><br>0 = Pass.<br>1 = Fail.         |
| [5]     | CALNS1      | <b>OP Amplifier 1 Calibration Result Status for NMOS</b><br>0 = Pass.<br>1 = Fail.         |
| [4]     | DONE1       | <b>OP Amplifier 1 Calibration Done Status</b><br>0 = Calibrating.<br>1 = Calibration Done. |
| [3]     | Reserved    | Reserved.                                                                                  |
| [2]     | CALPS0      | <b>OP Amplifier 0 Calibration Result Status for PMOS</b><br>0 = Pass.<br>1 = Fail.         |

| Bits | Description   |                                                                                            |
|------|---------------|--------------------------------------------------------------------------------------------|
| [1]  | <b>CALNS0</b> | <b>OP Amplifier 0 Calibration Result Status for NMOS</b><br>0 = Pass.<br>1 = Fail.         |
| [0]  | <b>DONE0</b>  | <b>OP Amplifier 0 Calibration Done Status</b><br>0 = Calibrating.<br>1 = Calibration Done. |

## 7 APPLICATION CIRCUIT

### 7.1 Power Supply Scheme with External V<sub>REF</sub>



**Note:** Total capacitance of  $LDO\_CAP$  pin is  $2.2\mu F$ .

## 7.2 Power Supply Scheme with Internal V<sub>REF</sub>



**Note:** Total capacitance of LDO\_CAP pin is  $2.2\mu F$ .

### 7.3 Power Supply Scheme with External V<sub>REF</sub> and External RTC with Battery Power



**Note:** Total capacitance of LDO\_CAP pin is 2.2uF.

## 7.4 Power Supply Scheme with External V<sub>REF</sub> and Internal RTC with Battery Power



**Note:** Total capacitance of LDO\_CAP pin is 2.2uF.

## 7.5 Peripheral Application scheme



**Note:** USB\_ID, HSUSB\_ID could be floating using USB or USB HS without OTG.

**Note:** Total capacitance of LDO\_CAP pin is 2.2uF.

## 8 ELECTRICAL CHARACTERISTICS

For information on the M480 electrical characteristics, please refer to NuMicro® M480 Series Datasheet.

## 9 PACKAGE DIMENSIONS

### 9.1 QFN 33L (5x5x0.8 mm<sup>3</sup> Pitch 0.5 mm)



9.2 LQFP 48L (7x7x1.4 mm<sup>3</sup> Footprint 2.0mm)

9.3 LQFP 64L (7x7x1.4 mm<sup>3</sup> Footprint 2.0 mm)

**9.4 LQFP 128L (14x14x1.4 mm<sup>3</sup> Footprint 2.0 mm)**

9.5 LQFP 144L (20x20x1.4 mm<sup>3</sup> 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                             |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2018.03.30 | 1.00     | Initial version.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2018.07.16 | 1.01     | <ol style="list-style-type: none"><li>1. Added HSOTGRST, OTGRST in the SYS_IPRST1 register in section 6.2.12.</li><li>2. Added the note “the SRAM bank2 has additional two wait cycles when reading data” in section 6.2.7.</li><li>3. Added the note that HXT should be 12 MHz for USB High-speed application in Figure 6.3-1.</li><li>4. Added the note “PCLK must be less than 96 MHz” in the CLK_PCLKDIV register in section 6.3.10.</li></ol> |

### Important Notice

Nuvoton Products are neither intended nor warranted for usage in systems or equipment, any malfunction or failure of which may cause loss of human life, bodily injury or severe property damage. Such applications are deemed, “Insecure Usage”.

Insecure usage includes, but is not limited to: equipment for surgical implementation, atomic energy control instruments, airplane or spaceship instruments, the control or operation of dynamic, brake or safety systems designed for vehicular use, traffic signal instruments, all types of safety devices, and other applications intended to support or sustain life.

All Insecure Usage shall be made at customer’s risk, and in the event that third parties lay claims to Nuvoton as a result of customer’s Insecure Usage, customer shall indemnify the damages and liabilities thus incurred by Nuvoton.

Please note that all data and specifications are subject to change without notice.  
All the trademarks of products and companies mentioned in this datasheet belong to their respective owners.